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ABSTRACT: 

PURPOSE: To attain plural byte parallel and simultaneous writing while 
efficiently using a storage area. 

CONSTITUTION: A file storage device using a flash memory element whose minimum 
deleting unit is larger than X bits, and whose data access width is (x) bits 
(x=X/p:(p) is an integer ≥2) through an X bit data bus, is equipped with a 
flash memory device 5 constituted of the (p) sets of flash memory element 
groups to which an access are simultaneously possible, dividing means 51-54 
which divides data on a data bus into at least (p) parts, data distributing 
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i means 61 which has at least a first function which makes the (p) pieces of (x) 

bit data correspond to one set of the flash memory element groups, and a second 
function which makes the (p) pieces of (x) bit data respectively correspond to 
the different sets of the flash memory element groups, and control means 56 
which controls the data distributing circuit 61 so that the first and second 
functions can be switched according to the number of the storage capacity units 
of the file management of the access object files. 
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(54) [RROgfr] 77y^3.^*U7y>f;PE»»B*,kat«M«i3aifeiK 



(57) «3E#) 

Xtfy hiO±^<x-^7^-feXffi^xtfy h (x = 
X/p : pfct2£U:tf)g|B r&Zyyyz/oimiVm 

7 ? -k x «j ig & p te co 7 7 y -> a * * U * T» £ <t o * 

ftbfc:75*->:i.;**>J«ll5, x-^/^X±COx-^ 

*^»<&t>p#§rr*»*ifW5 1-54. 'j>u<t 
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(2) 

1 

mmi] 7 7^©x-**xt:y ^©x-^/tA 

*tt#8»BX e y h «): D *3 < 7 f x M 

yb <x=X/p : pte2£U:©S&) T**7?vi> 

* y fefflb'S 7 7 v y 7 r <f Ji/Ett£ 

ttlEXtfy h©^-^nA±©x-*£'>ft<£t>p# i0 

1 ©«&<!:, ItrffipfitDxt:-; h^-^^-en-en^E 

rm^tH77< ;ko 77< ;M£S©Ett&ftimfc© 
E5^*4w*R*«irr**if»R£, 

MM2] tttftmn^mt. 1M79 

©x-*atig£Lfct><fc5* Mffi^-^^ge^S^fl 
7 7*fM3ttlM. 

mm 3 3 ttEtm^Rtt. iWB7 7^;K3D»Brrs 

P <S©E*&a¥tt©x-* JC** LX&ESS 2 ©»IB£ 
»*U l«©B**«ltt<D7 f -^C8LTttE»l 

©«&£&&•*-*,«, ttE^-^R^R^Mrra a? 

t'J 7 r-f MB«Sit. 
MM 4] ttrEE*£*l*&<h, ffrE7^->^** 

1 £ &»* 2 E«© 7 5 * ^3. * * y 7 7 -f JVEtfc£fi. 
'MM 5] ^n^^ASiVr-^^mfifeSt 

^fia^at, 75yi'jL>*y£Etftl*ft:£:bfc77'f 

;ue*^r£, «77-r^E*^a©77^e/a.^^y 
<nTv±zzmm?zyY-i)\s&toftm¥&zm&L8* 40 

«^*s^ttH«-r*«^«WE7r-r^Et»«w#a 

fcA*U ^E^^*»^S^©a:K7T^JPEtiW» 

^atL^^^^^i^^y^r-fjPEtt^a^iKtt 

^R©l!sr©x-*7**X«a«J*fc*a£. I0E7 7 
<7PI2«»IP^Sti7 7'f;i,5 ; -^O^^j2l31^7 50 
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2 

«*fc8*RttifoEttlB«^&3££tt* zmMQa* 

«frS*ifc-r*«IB«rU ttfi77<fM3ttMff¥R 

HWE7 r-f ^Ett^R#a5x-*tf:y hft^iirE^ 

»3^Rte*l,T*raS1i\ 3K#©&Sx-*«£-& 
3 * tf - * ©*» 0 IR D £fx -5 £ t fcttm t b £»M 

sK*©w?&5&s&it. 

mm 7 3 M&*&mx%m^&<DT-*T z-t*n 

lc$LV>fcfy hft©x-*££&r*fc«>IC&Bfcft© 
7 7 v ->i> * 'J »fc,fc 0 fifrffi? 7^f Jl<Elt¥R£tt£ 

u ^n-encD^^ypizv'-^>->v^iB^*«^ 

U «»©Ett««¥ffc»iCR ( 5;7 7<;K0ttttlC*V> 

H*»aHfc7r-f;«3BK'rSi:tK < I:DE«»«l 
&&t>Wto?Z%£iZ\mmMz%LT. W©«HWbfc 

a:^tc77^;pcD««ox-^^tt$nTVifc^^u 
»©&©«/*£&£ s nxv> * * * y #a> s JtftoEtfcg 

aeBftoflMXaSR. 

mm 8] ^^aagat, yyDwmmm*mx 

»E7r-f^E**«©E*li#iUT, *ft©77^ 

i's^U a75y^;**y©5r--*<7) 
*<M8*¥tt£7 7 <Y ;P§S©E1ftS*mtt L < 

he ip&wigRtf 77-f;i^7^-t:x ^s^r » ©e 

^^y^^^trr^-fexu Etft$ft¥ttft^iT 
*^a^»ctt» a&E£ft©75yvjL**y*^©iis 

MM 9] 77^>a^t'J$E*^U77^f 
^ElftaBlC^^T. Etfti"*** 1 ^>©7T-f ^©E 
tt$Adtttft©Ett$Ji¥^(cS:^«^(C», ^£tt$ 
fl^ttrtlr, *l:M<E«««ttt3MftMdnx^« 

*s«i^{firia©fli«$Ettfiaii^«Ett¥R$«A 

fcCt*»«t1"*77y^a^*U 77-f;pEta^ 

s. 

MM 10] i^©/ty^r->?^tt[|fc©^nEy^y^' 
3W^^nxu«jt%ij»7ic«ux. 

ME^ % U A y 5?3D«±^ t'J^y y ©x-^ AtfJ?J 

tc^r ^ ^ t y mmmt* e ©m^©^«5>©^»m^ 
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3 

* y *y Wr-9*w o ^xmthxm^xm^- 
9 m&r* z t^mt vit** y 

ItE* * U /t y *-*?W±* 7©y-* Att*) 

*©attfc**+*a©Affl»y-*»H t fca*.. £fc 

* y * y yoAto^x-^ ty-*© Amasr?* 
ttDjM.aamrr %7-*m*&t, &T-*mm 

¥Rfc»+*«y««##&©»w©fc*©«fl3V 
VFRS^Rfca*. RWB3V>FRfc^R©ifcKfc 
i: 0 flJEtlfe©;*^ u ^ y 3/©^-* D&*.&ttU 

y ^Adj^x-^ £fttrr* r £ £ pJtg t tfc^ * U 

»iF. 

[iBE©#«fcRgg] 

[00 0 1] 

a**£?*7r<;]'EttSR£*au&ttaa8»cft 
fcfc*a©7T*jior**xfcR*r*»**Bfc 

[00 0 2] 

B©%a©Mas?ttttttEttaRtt&£&2&a2: 

ViA^^Sa»gT*5. tttteift3Btt. 

©asicrtBSttTfr>*©]tfHattr?&0* a-tratt 

IC*$ft (0 7 y -f JU o Z. £ £ * «fc 5 fcfc X 
[0 0 0 3] 1EB5T& /— MMvM»/t— Ahy:/B 

*. £©fc»«»fc»<««aa#*#WB«5VX* 
E«g»CD^fc 0 fc¥3*#£E«|8fr£ Lfc77 -f JWE 

tta»^ttB*»rfri»*. w^-tf, #w¥2-2 9 2 

[0 0 0 4] 77yya^^'Jtlt «AAm^t8 
fc*. ***77<>l«ttKB©E**»fcbT*Mr 

afr^y©-^-?**, &£©4*a¥&«ttatt. c: 

©/ * 'J £«LH LT7 7 <f ;MBttBB*aBT*Blcn 
B&tt*jft&*ftU «Vi»^^(p]±$ti:Sx^LT 
1**. «A«aa*©««fc*D*W*fcT*i:*»3 

7^yi/a^tU©>c J aiS*aF-r**tt^ 777->a 

afc©¥ttft££aaLTi*a. ^xhiaaa 
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#T***XyA©«»BWfcLW*. 
[0005] 

7 7 -f Jl«KMtt^ h £fc*tBf8«8©E#©-f > 
*7x-X/XX£«#U ffi*y^X££ifffc©:i>/t 

^tryy-f saabw*. stile* o**#77-f;i> 

B&y^X^§£B£©5&tt£fi«T$Effi* 

[0 0 0 6] ?n.t>%. ^mmsmm^ m*?*? 
^sat&fco. an^eaa«ft(OT#*ic»afty 

-*7^-feX£*iJtB£-f*)&*, 5tt^EfiSI«tR-©-f 

7 x- a -m 2: ommr $ -tx ©«<fctt£iga>r c 

[0 0 0 7] *3ratt» ¥»fl«tt*T€:E«**#£?- I 
*Z£\z£r). 7**X©«aeB&a*Rk9l*tfFr : 

20 ^.*7^-fextta«>rt±ft«t^a»Eaaa«att-r 

[0008] 

[aa**ft-r*fc*cD*B] *BHfc,fc*7?y5p 

^■^r-fMaaaatt, 77^©y-*£xbry 

h ©y- * MA LTfelfrT S 7 7 -f A>EttBB?& 
5T, *^«**tt^iWBXtyhJ:D*#<y-^r 
^•feAffi^xtTyh (x=X/p : pl*2Rt©£ft) 
T*^7 7y^a.y^Ey3RT$:^^^77y->aLy*y 

7 7-f;i/E«aafc*uT» -tn-?nfp]^ic7^i:xoi 

y5'jLjl%y£B&. SWEXbTy h©y-^/tx±©y 
K^jW(*J:D^^tXfcpfi©xfcry hy-^$S5E7^ 

y 3^ a ^ ^ y *^«© i ai=^ft»t«a i ©tttet, 

UEpfiOxfcfy hy-^^-tn-?ntWe77yvi^ 

^ y a?-ff ©9ja©air^ft»t«a 2 ©a® t 

*y-*#E¥8:i:, 7^-feX^*77^f;P©77<^ 

flpa©E«»a*fi©»c*UT, m2&i*ij:ura2 

[0 009] 

Sa&y^X^gfiTtt, y-^7^-feA3W^-y^ 
3>Ka-^©^y7^-bAlCttttLTa<. /T-y 

±^3>Ki-^rt©cputaauTiMri-*ffl?tt 

fcU. ^©fc*ffi$ly>f A^Sa©y-^©g§li^R 
M©ytA±T»fbnTV>S. ¥«#$E«tt#^:L^« 

m»tzirz££mMm£tt&. 
so [00103 i>ti>Luifi*>camQmmjH£hT* cp 
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5 

**tt3W»*-3T*0, «/h©^¥tt««A«5 1 2 
-StC^^fT-5m*^&CD^l)&t (5 1 2xtm 

[0 0 1 1J aft. t\-V±)Vn>}Z*-20)7 
7-l)Vgm\t£<D5 1 2M hm&€-K«ID <l-fe£ 

2 \£ y bit A* 7yyv:i;**Urtt8 £y hAXT**l 
ii> l^y7£4®JB;fc7^XLTCPU(D3 2tfy 
hAX(C#^*&£)W&£. 

[0 0 12] L^u 4-fe^^±cojfettr^-trx^lc 

^4-t^^C07 f -^lCOUT> 42-y7\Z&mizm 

2 1 6@fc#*tT**fctri:, fc^yr/Kl 

2 8 (16X8) *lC»2-fe**<0 

5 1 2/t-f h 3 2 tTy b-f-D 1 6!§llC£ttT*&&tr. 

»4-fe*^<©5 1 2/t-f CICDWjftT, 4 

[0 0 13] C<0^\ZhX, 77-f;^4-fe^^T-p 
ITO4^*:/ttW7$'-feXMHgT. 8tt4>4-&??£ 

[0 0 14] 3-t991Slr>tt%&Mt* CPU©3 2tf 

[0 0 1 53 2t^^9om, ffl«3^6 
2*fc£*©7 7'f;i'T*$*g£\ CPU^ec53 2fcTy 
h0f-^$2^U -&K1 6fc?y h*T^2^yy 
cwrnm. »lt^^5 1 2>W M*. 1 

6 tfy hro3 2sfc»ijT2 9 t y5 f ic«*a*n, # 

f^^C2 5 6 (3 2X 8) MbT^>\Z#m-Z>£t 
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6 

hrt>3 2 0ic#Krc 2 

[0016] l-fe£*38t>fc*^ **Wi«Ja&A>fci 
•t^^O7r^;K0*&, CPU^6©3 2tfy b<D? 
-**4#*U -*fc8lfy h^l^y^lCT^-fe 
Xf*. l-b£*4>5 1 2/Tf M26 4|iKCfl>l*T£4> 

[ooi7] £i±«>J:3ic. as^-fcx-r***** 
ars*. *ttto%+ ^rnmmmzto^x^ 1 

* y 7Q> «/>»*x U 7 tc ttH-o 7 r -f * 

[0 0 18] fcii, *56^Ttt, 75y^:x;**U£B 
MOTS***. 7ftX»at:J;oTli«i;^ 
£0>raBfc*fLTI2. CPUtCUxYft^A^d^-St) 
OZm^ZZMZZO. fc;&ICCPUk:ftatKli£R# 
i^*»^A;&0fc$cPUtt^HTli— «« 
&&\X&tE<DVim<Drt—yj-)Vn>\Z3.—?\z 
20 KlSnw«CPUi:l/T«HWftINTELtt 
©1 6ify hfflS&±©CPUfctt;£T«;St5nTV> 

*. covx^^e^y-hl-^^tir^DCPUtt 

r*«H~cA<* 7^*feX)W7bfc^7iJ— h-rntx 
cpui4«ia©*ffftiiH'r-6. cnsi^r-owe* 

S83PC PUt^l)^&UTfiIftTRlffit^5$ff|T 
# -©©^I'^^x-^IS^CPUt^^y^aL^^ 

[0 0 19] 7T4frtt±-8mtkk99T&Lz>it*> 

7T-f^vX^Att7r^^(rcL^7^-feX3ti^: 
V>. L&tfoT, *ft-fe^^C0aLK7^-feXC0»^«# 

?&&mmm?*£>>\z?n& awmvwmzft&v 

[0 0 2 0] fiLh©*5C *«9!lCJ:ntt79y5/a 

xi.co c p u icx*-r * i^r-f m^tct: oa^c pu$ 
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(5) 

7 

[0 0 2 1] &\zr?*:XimWrL<-if\z&Vi2ft*T 
7£irXlc*V>T&**i;*;£K i/^fAOx- 

^^Ut-f>^y-y7^-feXLTifiS3fift*r^&ICt> 
[0 0 2 2] a«Wf«^«f^^*^HJ;n«, vXxA 

^5©7^-b^^«$«»&fl:Uifi5a7^-fex$a«ir i0 

*. *bT77<;l^gfc£fl&ttfcT$» 3>hD- 
[0 0 2 3] ^^'J*TP©^tCx-^e»IB^ 

iAs^tiao, EsaE&oim r-**a&©i$a 

[0024] 

[SUM] KT, *»9!»»«»Kfl«B«JBVkTff 

wriwirr*. 

[0 0 2 5] HlK«lp»«:;t-V^3>Ka 
-^<0*fiElC*%^77^->ii^ : E'J77-f;Pg«^ 20 
8«L&t)CD£?Kf. 0*, ltt5r-**:/ny*A© 
C PUT* *Q>*r-*?n7M\%* 2tfy 

/UTf-^MX, 7FVXAX* **tf3V>F, I 
03V>K&£fc*tf. 4tt*589!©75y3/ajl*U 
7r-f^S©7r-r;PWS-t»^^U^*fT37r-r 

®CDEiSttt(!j:i:>i^7^y>jL^^U7WT*0. 1 
7t2£SBttTfc£DRAMT*£. 8-fiM33 I O/t 

m i o&mt vx. 1 1 **s*««Et*8s 
i 2fc£#36tfen*. 

[0 0 2 6] fflSa I OAXf8»®88Kfc»J0£ 

fcrofc&£Aai'XrArtx3icA&£MUT. cpu 40 

ltH»»ffT*t>0fc#*.&tl*. 1311 |*|»->X 
xAAX 3 tt^ttSnAclHlK^ ^«5$-&^fc»(CC P U 
l£^tf£®8l;:&*&$n*£ay£{l^Tfc*. € 
U CPUllc4A5ns^D^*£<^-T**£ 

[0 0 2 7] 1411 CPUlKA*Sn*l'5 s -r«ll 
-f H9Isr% 1 STttJSLTCPUltCATJSft*. 16 
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TBA*Sll7W-#-HiU -&eoftf«ng|B l 6 
tt*-#-Fzi>hCi-7 (KBDC) £LTV>*. 

[0028] &tc, 0 1 as'XT^oftftemrr *• 
tifc«afijSff-r'«*B«7fc««snTVi*ya^ 

&tt 1 0 Sft^TftftOaff gfl 1 1 $ 

fctt£fx3. *LT, 77>fA£3l*fflLfcD*fMftUfc 
0 £ V> 5 ftff «DB fcli7 7 -tf JMMff EIMi?^^* 
j**>J 5d>efc*77yva*^U77-f;i'8«£iW£ 

II £0^&±S2#B£T*£ny^l 3£<fcDPl 

ffl»ffu *s@i&#cpuiic#«£5fcitt*^tf . 

£K*U W^«*14<&*y-Hc<fc9CPUlfc ; 

r 4 ^MffisIB 4HCPU1 n* 7 r -f ;Uft 
£ 0 C P U^«l^m$*tf»r *M*ftfrft.« J; 5 tcfc^ 

[0 0 2 9] 02ft 77^*>a^ ; &y7r^;^ll(0 
rtSMMteBWTrSHT**. 0*> 3, 4, 5, 13 

ftm<om&&mT:$>z>. 2 1 n vx^a/xx 3 m > 

^7x-X*fx5WvX^-C*D. 2 2tt77-fJMM 
4 CPU1 lCflfc*r*fc86©X:r-* X 

W3>X*, 2 3«7#irX**X*-M^*#^CD« 
£PvX;$\ 2 4«7^-feX-r^ftftCD-fe^^#^(0» 
«U5>X^ 2 5ttCPUia^#TS*!ia£:3T>F 
3-F£LTlt^*:3T>Fl'^X$\ 2 6H>X^ 
A/XXiKO^-^Oag^fTPSt^-Sx-^ V*/7*9 
2 711 77<J^W@K4rt©CD$!l«$iKJg 

2 8tt85»«t«:-C3&^7^vyi^ : eU 5©«»^ 
frSfOTPISfc, 2 9tt77";ya^t«JI:*fm<5 

$TOI5jgST*D, ->XxAO^Dy^«#l 3^|5rift 
twA^^tl^. 3 1 ttl/x-< MlPlsItt 1 5 (CWTJ-TStt 
ffllKWf. 3 2|lC:C!)77^>a^tU77<^l 
rt©D-*;WXX» 3 3tt7^y^iP<^U<&7^-feX 

[0 0 3 0] ^Clt02©77s;->i^^U77^^tt 

nwiftzmm'rz. cpuiB77^>a>itU7r< 
Mi^r^tzMi^cte. s/x^a/xx 

3«raUT7^irX*fT'5. *nfctttf Xf-^XP 
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9 

*LT&ic7£irX*-*1r^£x*-h-t:£ 

Sfcft^ h) $37>FW^2 5 -t 
LTS^X7 L -^XWyX^2 2£&*tf$U 7?"feX 

[0 0 3 1] U>hn-^2 7teCft£'f 

7x-^m^2 l©£3£fr^ CPUl^SOg 10 

2 3^X>K-fe^^U>?X^2 4> 37>H^X^2 
5«*«DT75y*>a«y 5 0>7£-feXrt£*fl2 

2 k#$&a,tc pu i 

[0 0 3 2] 3>hn-527ttCPUl*>SCD7£-fe 

fr5tCtt»^3»*tauc<!:^jLSn*<0T. DMA 
« W ® % 3 0 IC«t 0 ft % (C 7 7 y x a ;* q£ U 7 ^ -fe * § 

TV**. *<BfcS&(DDMA&»083O*>*yfBf?0 
K2 8^0T^-feXI*3$©jK^DMA©jeft^i!Sn 
>hn-52 7 *tfr5 dtlc^i. 
[0 0 3 3] DMAftf|[5J|&3 0 ttDMA&ff SfcaCxB 

a 2 8(i^©^-f^>^tc^7^-fexm#^^*r 

*M&®&2 9 tx-^oaafttx3. ^-^WWEIB 

[0 0 3 4] l-fe**<D5-f h7£-feXTifcft 

(2 ->XfA/U 3 fr£ © 1 0O7 £ -fcX IC <fc D j£ 6 ft* 

**iSWTMt* ->X^A/tX 3 ax- 
is' A'Xg£3 2t?y htUTV>*&dC»l[pl<DT^-feXfc: 
.fc*l52iT3 2tTy hCD^-*J&*fc£ft*. ^LT77 
y~>a. U 1 y 7©x-**B* 8 tTy h t LTH* 
<DT££ftfc5 r -5'£4[Hll£5mT77yS':x*^'J 5 
lC»e&tf *-©&&fc:3 2Hy h^-^fc 

82 9a*7^®IS£ffl^TfT7. *fc3BlCH:£*© 
'J — K7^"feXT»ntf. 77yi^J**y 
-H7mU3 2^hf-^^SLT, ISO 
/*X1E2t£TS. £ coSH^T^^XxAnx 3 <D#£ 

^wttf ; -^^ifii®?S2 9^±-r*ttssti^m^3 1 

\Z&ZC PU 1 A.(0«rtB|*T*CS*S. 
[0 0 3 5] Mfrfe**©7*-feX©«£tt, 5 s 

-^^®K2 9^7y^-r*x-^§S!ieLTT^^ 

x*wafttT3E«*fr-rs. «^«4-fe^^^a«iu 

-K7*-feXT**ltf. 8 tTy h7£-feXCD75y~>cL 50 
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y h<Dx-~*tf55j£T*fcfc. *>XxA/tX3<0^W 
ra<fe**<«&T2: fea77y>ay* 

, J5'vc0#$^<O^T4^y7 r ^7>f hT^-feX 
£froTfc<&g#&$. -C-^t&ViiT^^iOJift^ 
^oTL*^iE^7r-f^5r-^Tti^<&*. & 
«U 7r^Ettgtt£S*5S'X^ATli> 7r^^ 

^STfcD* fe£^ft£J:«7£'kX0>jli5£«?<f hi 

y-FT±<«t< UTv^na^^fira^BBft-r*^ 

s*i*fe^^tti?yy^4^«i|-r*, tv^r^-tx 
»asu-Kt^-f hovirfticfeviTfettffi-rn^ 

fcfcfc. 77r>i^'J 5K|&ttSftTtr>*-fc:5^m 
ttOx-J'fc, X-^ftiW^OWfttiaftLT^^T 
fc<klr>. -ecD8Sft*Bfi;UTtt77y^a^^'JOx- 

»«i/Tffi»-r*. 

[0 0 3 6] 6i^*0^7£-feXK»LTfcL 41: 

[0 0 3 7] cn^<o7^-fexm^^7 ! -^ 

[0 0 3 8] B3Tte, 5^XxA/XX*3 2 tTy 7 
5r>a^ U*8 try hOtfy h*ttfct^cr>«^ 

t)OtPI-O'b<0T**. l&f^lC. 4 ltt. DMAfW» 
@»3 0<O7FUX^CDfc«)C0*^>5 r T*D, ->X 
fA^ay^ 1 3-?>^X5 L A/XX3<0IO7^-feX (3 

v>k) ^»*^tt^^e»j7^-fex (37>F) 

SAAU CniC^^LT*^>S7y7 f T-6. 4 2 
tt, 3>hD-72 7<DD-*;WXX3 2*t^tt^ft^ 

DMAft!»Oje«lW^X^T*D. uOl/yX^i:J- 

H&s^&crcticfcowaroDMAtess^eH^r-ac 

i*»T€»*. 4 3 tt, -t>«0 n-*JW1X 3 2 
ft*-fe^^#^U^X^T*D, 7^-feXf *ir^^# 
^*m%&tS££\z£Q&M<0-t2*&n<0DUAl&& 

$&»««^ : EUMfllBlK2 8(CA^LT77yi/a.^ 
i EU©±tt7FUX^?r^-feU^ h©#<D^fcffiffi 
$ft*. 4 4tt. DMAte2l^tC#Sf»®?5TfiIffl$i: 
* fce6 CD ^ -f 5 > ya*«8^-J-S ^-T S > ^IhIKT* 
*. 4 514, *£>*4 li-fe^^U^X^4 3©ffltr 
*^T^Uft»@*28*t«4'r*^ J Ey7KUX 
T&<5. 4 614. **U7KUX4 5am$i\Z&t>KT 

SLfcrzt^vmnimr&z. 51, 52, 53, 5 
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U 

4tt, <8Hyh) (Dx-^y^Tifc 

(3 2lfyh) (Df-^7yf^lT^5. yXr 
A/XX3t3x-^£D0-*D3 1 t"T*£, 5y?5 1 

liD16-D23, 7y^5 4liD2 4-D3 l&-etl 
■^n^y^-fS. 5 5li, cnSr-^^v^O^yf 
5 6tt, D-;fr;WtX 3 2 t&m 

£1->*X*5 6fcU-F7£*XI505m7^i:X^ 

d £ fc J; 0 5 V^fc^CD^^tf)^ ^>^£^yx 
fc##£0i&5 5fc»*-r*. flTr-^77f 5 

1, 5 2, 5 3, 5 4<D*n^nitA7J?'*7y3 1 te** 
#5 7, 5 8, 5 9, 6 0m. ttiLtf " 1 
ttlK. 7^m5 7, 5 8, 5 9, 6 0^-0 

ta/u3i:wws. ^ w 2-&K^-rntf, 77 

^m^5 7, 5 Bt:mm\zmi3U 

9, eofc^tia^-r^ti^Jiii^strfT^ 2 

-feXLT3 2fcTy h©T-^£^LT->XfA/U3 

teal*-*-*. ifc M 4^m«77m5 7, 

5 8, 5 9, 6 OtC^fcta^LT, 4?y^©77? 
-> * y & cDx-^ * 1 ®£**7 £ irX LT 3 2 fcf 

v kcdx-*££#lt>'X5 l aax 3 icm^**. 
[0 0 3 9] h7**x©tftt*fc:r-*7 

7^5K 5 2, 5 3, 5 4fcE&*K:7y^m#£2So 

CifC&S. 6 5r— ^7^7^5 1, 5 2, 5 3, 

££0£tt*x-*#ElsIBT**. 6 2tt, 7 7 r> 
5fcx-*#£[slB6 imfc3 2fcfy hCDx 
-*/tXT&*. 6 3tt, T^-^fiE&e l<Dx*-* 

2, 5 3, 5 4£8#2n, fc5-;£tt;7 5y^a.;*qe 
U 5tC&]B£nTV>*. 77yya^U5<fflTii3 2 
Hy h#©A7Ji:fcoT*D* 777*>a^^'J 5CD£ 
5 L yy*4felc^tTiara*jOtfy hf* (\fybO 
-7) (tfyh8~15) (t!yM6-2 3) (tfy 
H2 4-3 1) W32Hy hiLTA^LTV* 
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tO 0 4 0] d<0x-^©7>EtCOViTHl 2, HI 

3, Hi4tctD^wn»awr*. ^n&^Htt, x 

X*5 6<&&£«m:;*bfct>fZnNfc*. -ttt* 1 *, 0 
1 2«iS«7^-feX-fe^^»*tK HI 3ttStt7^-fe 
Xiz£*fctf2, Hl4tt^|ft7^-feXi:^^ft*t4, 

4o^^U^<iftit7^-feXf^fcJ:r)4tt®0 ' 

&«7^i:Xi:£^ft#l<o$£icra4t?0i/Xx 
AIM^T^^'fcXtfcO, att7£>1:Xi:^» 
^2<0«^tCtt2O0vX7 i A't?-f ^;PT17^-feX, 
&«7 £ *fe X -fe £ *»#4 \Z\t 1 O © yXf Alt" 
-T^T17^irXi:^. 

[0 04 1] *tt7^-feX-fe^^ft^l(D*^«4r?C 
^Wtfept ; eu^^c»r7^1rxr^fc: ( fc0 4asic , 

#tf5ft**«, &tt7^X»3&t2Rtf4fcj3UTtt, I 

^©^qey«$ja^tcr*^»wj;>)^«0 4asic^ ; 
ft*. o&ton%\z&Q&&*ttm j 

[0 0 4 2] fc*, Mfrfe**^l*fctt2<!>y-F 

#1 (012) ©ACOU-KfcfcViTfc, 
tM^T, 77fl-^>J»l, 5y*2-**U 
»K 7^3-^^J»l, 7yx4-;**upi£ 

^^e<j»©ic»iRUTt)*t)^vi. cntix-^cDie 

[0 0 4 3] $€»tC^ftW^»2^*HlAn«, fclAtfl 
•fe^W^-f K7^-kXT«Hl 2«0ffiU 3 2lfy 
h©r-^/U6 2<0o'&7^'feX^«©77y^jL^ 

*'j^ir>tcsa$nfci/^ liHiiTfix- 

^5yx5 1lC, 2 0@-ctix-*5yx5 2fc, 3© 
eT«x-^7yx5 3tC, 4@ITKT-5'775 i 5 
4t3, £TF5 l^e«*IC»DigUT77y->a^^U 

[0 0 4 4] 2-fe^^<D7-f K7^-bXTtt, T^t)^ 
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^-^«2/W h®?^ hTfcntf, H13J:D32t: 
v h 0^-^X6 2 (D^fcysT*^ liSffc 
&83nT^*2/Vf h<Dx-*£LTl®B07£-fe 
^■Clif-^^^^Sl, 5 2«fcD, 20gCD7£-feX 
Ttt5 3, 5 4£0x-*£3W5[»?, OT££fc$0 

Mif * 2 ^(D^^t 'J 1 EgCDT^-feXTttx-^ 
77^5 1, 5 2»C, 2®a©7^i:XTtt5 3, 54 

[0 0 4 5] 4*.$#V>y<1 h7£i:X, ffc^x- 10 

7^^^77y>a^U 5tf>#foi:fc!h 3 2fcf^ 

-^7^5 1, 5 2, 5 3. 54£&tt£ft, 1+M 

£;K07^-feXT3 2 tr* ho75?-fexat|£7-r*. u 

tO 0 4 6] «±<0ftf^i&fT'5fc86tCn>hD-7 2 7 
»DMAIimisI»3 0eSAfi^ltS|ir(C« ZtltLTtZ 

*• a? 

[0 0 4 7] Kafco&*te» ffti£C0J;3IC, »»CD* 
*U#fcEf$K7£-fcX£fT3*£, 

[0 0 4 8] 05fc$3UT, 8 1-8 4 ^n^n* 
*USM~4£;*LTV>*. (1) tt, fc*g&CD 

7r<^#^^fr^n^«^^u (2) 

(m-n) <Dmtt7yfM^ nte&:7 y-f ;PrtcO*fe 

(3-2) tt, 7T-i)V&** 30 
3 SCO 2*£5'&£^'r. €U §7r-fJP 
Ql£U<0-fe^l;:*tLT, £0>;**UfM0xy7 (1 

[0 0 4 9] H5 (l) tc:fcv>T. (l 

7Kl/X£^A*C£;5>*T£*. L^U 7 
2tC$3Wrtt, 2-l30>$2-4$T£W7£-fe:X& 

Ztl\t. 7KWX;1X£* 

ia, ^^up^cs^a7K^x^A^^^^^o7Ja 

A4M2(D7£-feXtC43UTtt. 2-l(±m3fiT7^*fe 50 
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XU 2-2, 2-3£PP£7£-t:XU *£fc2-4 
fcffl&¥#T 7 £ -feX f 6 £ I* 3 7 £ t X^St* £ 

tf*. *ct?. Sfc*7Kl/X*^**#|j£fl£B9l;: 

[0 0 5 0] H9tt, **US££4£l,fc££CD;*:e 
'J MMelB 2 8 rtC07 K PX^IhI»(D»^WT*^. 
0*, 2 0 1^2 0 4tt77y^ ; Ey5S«firrS 
4T3SM*Uf*T*D, 2 0 1«^lCO^tU»a, 2 

0 2te3S2CD;**>Jt*b. 2 0 3te£3<D;t*!J3|c, 
2 0 41*314 ©^Ulffdr**. 2 0 5tt, **U# 
blr4A^±^7H^XcO7^^0Kb. 2 0 6tt** 
'JPctC^^^y^Qttc, 2 0 7(i>t^U»dlC4 
A*5y?MH]&dT**. 2 0 8tt, ^%UfHffl9K2 
807HWXAX (H3<04 5JC^) , 2 0 9H7K 
I'XAX 2 0 8 ©T&7 F PXTife*. -£<D7 H PX fef 

* * Wi 7 r -f ;HTSO*^{i <D S 7 £ <fe 

x**<m;:*§iir*7KuxeyMfc*r*. wai*, 

x-*ft$«*Jti<fcrtt5 1 2A-f hT*ntf, 9 fcfy h 

r-f;^s©*/hmfi»cffl^-s7Huxtfy bftt-r 

^dt^SftT**. 2 10tt, 7HUX/XX2 0 8<O 
T&7 HUX 2 0 9 ^ »Ufc±{flr7 H PXT*$. m 
U ^ ; EU» : &7^-feX*rs^>tw^S7i$^lC±&07 
HUX»m<fe(Ofr 5. 2 11fit ^ ; EU»b$7^ 
•fexTSfc*K:7KVX5^^b(c:Ett$nfc±tt7K 
PX, 2 1 2tt^^U»c$7^-feX-r^fc©lC7HU 
X5y5 1 ctCffitft$nfe±fi7HUX, 2 13tt^ : EU 
S d £7£-feXT*fc&l;:7 y^d fcE«$n 

£±ffc7Kl^XT&*. 2 1 4im'J^a2 0 lODjjt 

2 16li^^'J^c 2 0 3CO/ ; eU$Him^, 2 

1 7tt>*U*d 2 0 4CD^^'J$jWm^T*-5. 

[0 0 5 1] H9<D#|^IC*^T, ^^U»a36^^t 
'J »d £T S^t7^-tXT-5»^lCW:^«)7 H PX 
77f2 0 5-2 0 7fCHE-tHfn©^*>J»€7^irX 
r^±(47HWX$r«$^-C^<. ^LT, 7^-fcX 
Sff^lSlrtt, T&7K^X2 1 0ttf^T©^^'J# 
iC&a-C**fc«>, 7HV-X/^XtW^U»afc^7 
^■feX-r^fcs£»«57HUX€«l&U ^^UPa£WcO 
^ * «J <b 7 HI/X77 ^®»3fc fc_h&7 K U 
XIC^D7^-feX^fr^. 7i*. 7^-feXCDIMWtt^t 
'J®©©#2 1 4-2 1 7l:«fe&*U 
Pat^^'JPb&HtC07^-feXT&n«, ^^Ufftfl 
flff 2 14, 2 1 5^nt^7^er-r^tC^^«t3»Cr 
W^.«^ ; e'JPdfc^t©75'^X^^lriT 
tt, ^ : e»JPalC(i^^'J^©m^2 1 4£7^tV7 

tc l ?i ttntf v>a*fc ^ 7 h x#-5 a e nr t> rasa 
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i«*fc©»K«*A*C B9<D«ricT 
tt, ;**y#a07KWXyy^££ttt*a;:£:#T£ 

[0 0 5 2] £U:(D*J6«IC<kn^ CPUlttttttW 
£ tb m to t >®W $ 7 7 h ^ x 7 (C J: 0 ffikt % £ t ifiT 

-**5££7 >^y ^T-f a >3»»fi5«*fe#*. £n 

[0 0 5 33 ^JSWTtt^-^XSv'XxA 
3 2tfyK ^y^a.;**y 8ty h£bTK91£fr 
oTZTcW* 1 6£y h*frfe©CPUl-*>6 4try Ml 
tfrDCPU* $&1 6 try hAffl^CDyyyS/a.;*^ 

->'X * ft if 0>*riW» 3 > h D - 9 D ^ 5 Afc £ 

^CDHtfflfcH 1 5 ICtkL*:. @ 1 5 ttfctfy hUCDlfi 

fc.O, 4tTyK 8£yK 16tyK 3 2tfyh£ 

TfcO, fflS¥fcflm«8<0 8lfy MfcS. aftO/^V3 
>or>£&T**l 6 tTy K 3 2 tTy K -etTWfcW 
fc/W3>*>ft&£:3>tr;i.-$'<D6 4tfy K 128 

U y-* t'y «©*#*€r*>»&fc:t» y *©(Mtt 
[0 0 5 4] fc«U ***WS*a67 f -^^E|g»o!) 



#SI¥6-26 65 96 

75 

;**Ux-*tTy hft^tv^ftft^tt^tyor- 

»J **Kafc*^*S d £tfT£Z. CCD 
ft fctt > * ij C £ fc* •) PWfcT^iHE 

[ElttH^tt^^ ; EU©7 i -^O^E&^ 9y^«H 

[0 0 5 5] fcfc. *^J6«Tli7yy->o./^»J^> 

&^i£fTAS7yy->zL^^U^^-rnil H©«k5 I 
fcy-f hny77«&I!&<fc*. 7^y ^n.;*^ fc ; 

■TftCt^W*. *bT5^ H7£*XG>ftlCtti&fc 
7^y5/a^*yfc:#*a*r^ h/ty7 7lC»#& 
^^fToT^XxA^^Ox-^^E^ttTaiCy-f H/t 
y7 7*^7^y->3.^^U^O»*>i**fTyC:tfc: 
?^<5. e:©«^coi53fiW©«l^cH$H4tc^Lfc. 
[0 0 5 6] B4f* KacO#^ttCtl*r(CK§gbfc 

irX^U-H^y< h^lc<toT^-^ElHlB6 1 1 

^^-^WiCftJlfrr^3 2 try h«(Dy-f Wty7r» 
7 3ttT-^tl/^^7 l£#>3tt*_*fc8£><DU-Fy 
-fhm^T&D* 3T>h>^^2 5C0x~^CO-*« 
£A*r^t^^. t>U7^*feX*ty'f hT^tltfx- 
^»fi0tt6 1«r7-f h/Xy7rlC»»U 7<hr- 
^^y-T hAy77tC»lfiUTvXT-Ad^<D5 i -^fi 

-HT^n^x-^ES^e 1^7^yvi^^UtC 

^U&*ffltT'bVX^A}5»6*ritf»aft7^-feX30« 
[0 0 5 7] *fc7r-f;M»31fl!)jafi«tLTH5 4« 

; 6U77^;KDa>hD-y*t^^tlCftD» V7h 

^x7C-fcaaffW4>tai*. Hsic^^sj^Tij-t 
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LT, 7 7 y *> ^^^6 U t U WIXU 7 

x. m*Q***mizxtitemxt)Tifi$iL#znz. 4 

1-1-1-4) fc#l,T, H***'JPl~4©ll|i 

&£*xy7#aiDttttsn*. mu ^issnttein^ 
©fc-fc £ U 4 z><D&&igmx y 7rt k:#ttU 

Tfctt^nS. 2ir^ (WLfcr0©l-5-l-6) 
fctfLTtt. 2^©;*^yp©ip&$*xy7tf&b£ iff 

rsn*. c©*^^^*©^--:?^^©^^ 

«XU7rtfc#ftl,Tfctt£n*. 7 7-OH©Jgft© 

■fe * * i - 7 fctt»a©* * y »©*tt*axy raw 

Co 0 5 8] 2*****tM***0#*» 
»fc«H)|T*. HI 0U4/H hEI9*&*©«*^ 

u hi 11*2 /vf KRBwa*©«&a%-r. irafitP? 

[0 0 5 9] HI OfcfctriT* **ypa-d^©4*fe 
^^H»»a*®«l€*-r. H*, 2 1 , 
©*>XfAA7^60f-^^^l, 3 2 fcfy h (4 /t 
-f h) £¥tt*LT»&niC<*. 2 2 2-2 2 5 tt, 
8Ky h h) m#©r-*©&L#^£;*LT 

*50, 2 2 2liirW bEGy*-** . 
@©x-*, 2 2 4«3A-fhg. "2 2 5tt4;WM 
©x-*-?<&*. a&LT4-fc^#£LT2 0 

hnxT^sfcfe, iyt-r hB^s^w ntws 30 

ISlCgftStt, fitTfcPWra&S. 5 1-54ttH3T 
[0 0 6 0] 4/Vf h^©HB§«a*T**fcft, 3 
l-5 4fcttlrtL&&, §/H h*tjt t ijp a ^dfc» 

HBTti, {S5lC±v &i:£*£ft£©;**y» 
MtfiH*. **£*©x-*tt»£®**yi»©*lc* 

jWsn*©T«fc<, ^^y*a-dic»«UT»ta 

*n*. tttZU 4^*±#©^-*#;* ; e'JS$a- 
d©4i*^#©XU7Kte;W£n£C£tt3&Ti& 
S. 

[0 0 6 1] B 1 1 K*tt>TI** ^'Jifai^yp 
b-N©2 W hlTOS&*©ffi|£a«-r. 
[0 0 6 2] 2;H hft«E»raR««»5fcl& i 3 50 
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I* 

2 fcf y hx-*o£ 0 4;^h Zmmzr-? 7*^5 
n, ^©2/WhjOW : EiJflaWty»bl:i 

&t**vmbtzi;w hr^sksn*. c©^^ 

»CtT* lt^^<05 12/^ tl 

zt* m>xn2 0't99QiJw bMfrtmmzhx 
**yp a . b©&«8#fc#£fc3;n*. ;l©*-& 
8 1*^* yp©*£^sn*©T 

\Z* M2*?5rfeJRl-fcjr££tttvr>l%ypa, blZ 

iMi,x#z&xn*. 

[0 0 6 3] ¥-* fe^^©«a*fc^ViTliH^L^ 
£©*£lCfcL E^Kr-^y^S l~5 4©fc 

^ hx-^d^»^>i^yp(cifrttsn$. c©« 
^©* i ^ * ©?*-* mm* tir\z&fc<D** y p 

[oo6 4] &±a>*#36>*<k3fc, aK&ctfc, a 

±©»#©IS*, 77y^3.^*U3l^©«/h«i*tt 
(ElCTttl-fe^^ftlCffi^l-SS 12^-T h) ©X 
y 7ft fcttHfc* 7 7-f ^©T^tfSfc LfcV>£ 

S»J©7r^;P©7 ; -^*^*-r5J:t^<» ao, 
y©E»xy7^5&»=l'iffiL,^tea5t/t-f httfljpi 

[0 0 6 5] i5iE©<fcotC, H5 (1) (i*^ea©7 

7-f^©«€ra^ffbti^m a s (2) n-e©a 
*47r-f jwc t)v>Ttt55ii sn^o 7 7 -f ;v£*#* 

ATU$^fcttlB*^LTM^. H5 (1) 

n*77-f;p#^JB, -fe^^*^)i»cs^^^y*t»i 

[0 0 6 6] as (i) \zmvit&5tz* ^^y»fc^ 
^±i;)ivi < t5fc77-f;w©-fe^5'^ a^&o 
\zmtbx#mr*h<Dt?zt* yr-ij^mm^oy 
T^^$l^^fc*^i:liH5 (2) tc^-T^^fcift 

©llS£LTttigttWK:^^<fc5tr«iW'r'5. 0*0. 
7 7^S^4#©77<;U£«trr*£> (1) T« 
4-1^64-5 *T© 5 -tZf&mt&tlXUZtt^ 

(2) T2-fe^iUjnsft*£. 4-i*M^eyp3^ 

^M*6$tlTV^fc«>, 4-6. 4-7©»lP^«^^ 
'J»2. 3©X'J775«««$n-5C:ttCft^. -t^^ft 
^*aJaU)S:7 7-f^©«ji*^lX«, C©^^«4-5 

i4-6t2-fe^^stt-fe^^£brafcn, 4-7^ 
vm>*&rtzz.t\zixz. cne©7 7-r;i^i©» 
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m& t L X >X r A*>6 CD7 £ t:X-fe£ * <Offi£tt R£ 

t x v> * taa w^&scDis^ta«ft ut 

[0 0 6 7] 0 61Cte£8ffi8©«£;*LTt**. 0 
8 5l±**yfc*#J3ttWS7 7^I^*T* 

* M 3"tt*<EyWW, 5 "ltt©**y» 

<0*©7KUXT**. 8 9, QOIiUfiH^r-f^f 
-^8 6, 7r-f;Vx-^8 7(0&a7KU'XT&*. 

8 5#77-fJP#^4. SGDx-^T&fcfc 

a*. y*#*. 

C07FU-XTfc*. MCl/T, *«fll$89 2tt77'f 
ttUfclr>«£<&3KLTH*, O£0 77'Ot'#*t4<D7 

p u«7 r< ;n»»©fta»ftttit *«af4«i»ia 
T7 7 -f ;hh»©3 > h D-7«s2ffm«#aua^ 

6**y©&aftfc7^X£?T5£<!:£,fcD, -oca 
7 7 *f 0 a A< 6«ianaiftlAttft«<MCLT« 6 
T^ft UTU S 7 7-f ;UT t>B»fc>fc7£-feX#pJtg £ 



8RPF6-266 5 9 6 

-a? 

»fc*7KU**A»T***##BTa*. fc«U 
WXttfta-C*. -«lfiU:OJ:tt7H^lrRai/Tei» 

aTjUKHtC**. 

to o 6 8] *fc^^u<HFa*ic»a««fi*ati 

[0 0 6 9] HTttaKO^yf^t/fcl^O/t** 
BTfc*. 0*, 1 0 m*^yAy>b— 7. 1 0 2*> 

6i osttisiaoaaftfto&jt^y^y^ ioe^ 

610 9 tt;HEy /ty fr— 5? 1 0 1 COAffi^-^flH? 

x. -tn-en— ot— ^©^^y^v^o-?— ^Atii* 
altera*, emf^y^y^io 2**8 try h© * 
x-^AfflaT&ntfioe^eiogsT^Brcsfc; . 

y hx4 = 3 2fcfy Kcox-^Am^aT^ocitlc I 

a*. 1 1 o\tzti*><t>* : £V?y7tAmj]iktt& • 
*t-*a»s«*'r*«*A*a^ nittiBfta j 
* 1 1 2 tt8tt«8ft£®K-e**. *«y 1 0 1 

oa-tffiL 7-^Atfi^«fl 0 6^610 9©»£ 
fcfc-SA^ifi^l 1 0££DffoT^67^-feX£^fx 
1"*. £©a££fct£ifi©01 2, 013. 014cj><fc 
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(54) [Title of the Invention] Flash memory file storage device and information processor. 1 
(57) [Abstract] (Modifications exist.) 

[Construction] j 

In a file storage device using flash memory elements whose minimum deleting unit is larger than X bits and access 
width is x bits (x = X/p: p is an integer equal to or greater than 2) through an X-bit data bus, it is equipped with a 
flash memory device 5 consisting of p sets of flash memory element groups accessible simultaneously, a dividing 
means 5 1-54 which divide data on the data bus into at least p parts, a data distributing means 61 which has at least a 
first function to make p pieces of x-bit data correspond to one set of the flash memory element groups and a second 
function to make each of the p pi eces of x-bit data correspond to another set of the flash memory element groups 
and a control means 56 which controls the data distribution means 61 so that the first and second functions are 
switched according to the number of storage capacity units for file management of the access target file. 

[Efficacy] 



It becomes possible to read multiple bytes simultaneously in parallel while effectively utilizing the memory 



area. 
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[Scope of Patent Claims] 
[Claim 1] 

In a flash memory file storage device which is a file storage device storing data through an X-bit data bus and which 
uses flash memory elements whose minimum deleting unit is larger than X bits and the access width is x bits (x = 
X/p: p is an integer equal to or greater than 2), a flash memory file storage device characterized by being equipped 
with a flash memory device consisting of p sets of flash memory element groups accessible simultaneously, a 
dividing means which divide data on the X-bit data bus into at least p parts, a data distributing means which has at 
least a first function to make p pieces of x-bit data obtained by the division correspond to one set of the flash 
memory element groups and a second function to make each of the p pieces of x-bit data correspond to another set 
of the flash memory element groups, and a control means which controls the data distribution means so that the first 
and second functions are switched according to the number of storage capacity units for file management of the 
access target file. 

[Claim 2] 

The flash memory file storage device described in Claim 1 characterized by the fact that the control means controls 
the data distribution means so that data of different files do not coexist in the memory area of the minimum deleting 
unit of the flash memory element. 

[Claim 3] 

The flash memory file storage device described in the Claim 1 or 2 characterized by the fact that the control means 
controls the data distribution means so that the second function is selected for data of continuous p pieces of storage 
capacity units in the file, and that the first function is selected for data of one storage capacity unit 

[Claim 4] 

The flash memory file storage device described in the Claim I or 2 characterized by the fact that the storage capacity 
unit and the minimum deleting unit of the flash memory element are equal to each other. 

[Claim 5] 

In an information processing device having as its components a central computing/processing means which 
processes programs and data, a clock oscillation means which drives the central computing/processing means, a file 
storage means having flash memory as its storage medium, a file storage control means which controls access of the 
flash memory of the file storage means, an information processing device loaded with a flash memory file storage 
device characterized by the fact that the same signal or synchronized signal with clock signal generated by the clock 
oscillation means is input to the file storage control means, and that the central computing/processing means and the 
file storage control means perform synchronized actions to send/receive file data. 

[Claim 6] 

The information processing device described in the Claim 5 characterized by the fact that when the one-time data 
access width is different between the central computing/processing means and the file storage means, the file storage 
control means is equipped with a means to output a status indication signal indicating whether file data are being 
processed or the processing is complete, the central computing/processing means has a function wherein it receives 
the status indication signal, if it indicates that it is in process, it halts the process until the processing is complete, the 
file storage control means has a data bit width control means which adjust the number of data bits dealt with by the 
file storage means to the processing data bit width of the central computing/processing device, the data bit width 
control means shows to the central computing/processing means that processing is taking place using the status 
indication signal, and allows it to stand by during the period necessary for adjusting the data bit widths, and 
performs data exchange by adjusting the processing data width of both. 
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[Claim 7] 

The information processing device described in the Claim 6 characterized by the fact that the file storage means is 
composed of the number of flash memory groups necessary for generating data of the same number of bits with the 
data access width of the central computing/processing means, wherein sequential order is regulated for the memory 
groups, storing files over multiple storage capacity units following this regulated order of memory groups, and when 
the number of storage capacity units increases by updating a once-stored file, the increase is secured from the 
memory group regulated in order as the next of memory group where the last data of the file were stored in the 
previous storing. 

[Claim 8] 

In an information processing device equipped with a central processing device and a file storage device, 
characterized by the fact that multiple flash memory elements are used as the storage media of the file storage device, 
where the minimum deleting unit of data of the flash memory is made to be equal to the storage capacity unit for file 
management, and if the number of storage capacity units when the central processing device requests file access is 
plural, the multiple flash memory elements are accessed simultaneously, and if the number of storage capacity units 
is one, one piece of the multiple flash memory elements is accessed. 

[Claim 9] j 

In a file storage device having flash memory as its storage medium, a flash memory file storage device characterized 
by the fact that if the storage capacity of a file to record extends over multiple storage capacity units, it is equipped 
with a chaining information storage means which records information in the physical location where the next storage 
capacity unit is stored for each storage capacity unit. 

[Claim 10] 

I 

In a memory element where multiple memory chips are embedded in a package, a memory element where the 
memory package is equipped with the corresponding number of input/output data terminals to the total number of 
data inputs/outputs of all the memory chips, equipped with a data control means which controls 
switching/connecting input/output data of each memory chip and data input/output terminals and a control signal 
terminal for instructions from a memory user to the data control means, making it possible to switch/connect data of 
the multiple memory chips upon instructions of the control signal terminal to connect input/output data of an 
arbitrary memory chip to an arbitrary terminal of the input/output data terminals. 

[Claim 11] 

In a memory element where multiple memory chips are embedded in a package, a memory element where the 
memory package is equipped with the corresponding number of input/output data terminals to the total number of 
data inputs/outputs of all the memory chips, equipped with a data control means which controls 
switching/connecting input/output data of each memory chip and data input/output terminals and a control command 
setting means for instructions from a memory user to the data control means, making it possible to switch/connect 
data of the multiple memory chips upon instructions of the control command setting means to connect input/output 
data of an arbitrary memory chip to an arbitrary terminal of the input/output data terminals. 

[Detailed Explanation of the Invention] 

[0001] 

[Field of Industrial Application] 

The present invention relates to information equipment loaded with a file storage device having flash memory as its 
storage medium, and especially relates to a file access method of file storage devices suitable for information 
equipment where high speed file access is demanded. 
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[0002] 

[Prior Art Technology] 

In today's general information equipment starting with personal computers, auxiliary storage devices are almost 
indispensable peripheral equipment. Moreover, in general, auxiliary storage devices are contained in most 
equipment, and arranged so that the users can always deal with flies of large capacities. 

[0003] 

Recently, there are increasing cases where personal computers of notebook size and palm-top type are used, and 
portability is coming to be regarded important Therefore, in place of magnetic disk storage devices which are weak 
in terms of vibration and have a large power consumption, file storage devices having semiconductors as their 
storage media are drawing attention. For example, disclosed in Pat Open Hei 2-292798 Public Report is a 
technology of a semiconductor file storage device using a flash memory as its storage medium. 

[0004] 

Flash memory is nonvolatile memory which can be electrically rewritten, and because capacity increase and cost 
reduction are possible, it is one of the most effective memories as storage media of semiconductor file storage 
devices. The technology in the Pat Open Hei Public Report uses this memory to solve the problems in constructing 
a file storage device and devices for improving the ease of use. For example, it proposes a method of overcoming 
the shortcoming of flash memory in which the elements become degraded by frequent rewriting, a method of 
increasing the speed in a phase called, deleting necessary for rewriting a flash memory, etc. Also, as an interface 
with information equipment which becomes a host, it proposes it to be the same as that for magnetic disk devices, 
directed towards the construction of systems that can replace magnetic disk devices. 

[0005] 

[Problems overcome by the Invention] 

The semiconductor file storage device of prior art technology uses the pre-existing interface bus of the host 
information equipment and places importance on compatibility with magnetic disk devices. Although this makes 
the semiconductor file storage device to be easily accepted by the users, in return for placing importance on 
compatibility with magnetic disk devices, no consideration is made on superiority of semiconductor storage 
elements to magnetic disk devices. 

[0006] 

Namely, although semiconductor storage elements enable very high speed data access because they are static 
recording media unlike magnetic disk devices which pick up data from rotating disks and perform writing, there is 
the problem that the superiority of this high speed access cannot be utilized with the same interface as with magnetic 
storage devices. 

[0007] 

It is an objective of the present invention to construct an interface which achieves high-speed access performance to 
the maximum by making semiconductor storage elements to be its storage media and to provide new auxiliary 
storage devices which improve the access performance, which is a shortcoming of magnetic disk devices. 

[0008] 

[Problem Resolution Means] 

The flash memory file storage device by this invention is characterized by the fact that in a flash memory file 
storage device which is a file storage device storing data through an X-bit data bus and uses flash memory elements 
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whose minimum deleting unit is larger than the X bits and access width is x bits (x = X/p: p is an integer equal to or 
greater than 2), it is equipped with a flash memory device consisting of p sets of flash memory element groups 
accessible simultaneously, dividing means which divide data on the X-bit data bus into at least p parts, a data 
distributing means which has at least a first function to make p pieces of x-bit data obtained by the division 
correspond to one set of the flash memory element groups and a second function to make each of the p pieces of x- 
bit data correspond to another set of the flash memory element groups, and a control means which controls the data 
distribution means so that the first and second functions are switched according to the number of storage capacity 
units for file management of the access target file. 

[0009] 

[Operation] 

In magnetic disk devices used in the current person computers, data access is slower than the memory access of the 
personal computer and does not have to operate in synchronization with the CPU in the personal computer. 
Therefore, the give and take of data of magnetic disk devices are performed on an asynchronous bus. When a 
semiconductor is made to be a storage medium, because it can follow operations of the CPU, it becomes significant 
to make it a synchronous operation. 

[0010] j 

However, as a problem in such a case, there is the issue that the CPU processing bus width and the data access bus 
width of one chip of flash memory are different. Although this bus width difference can be solved by usinglmemory 
chips in parallel in cases of DRAMs etc., flash memory has a fixed deleting unit where the minimum deleting unit is 
512 bytes, for example. In this case, if multiple chips are utilized in parallel, the capacity of a deletion unit that is 
deleted at once becomes (512 x the number of parallel chips) bytes. Thus, the deleting target capacity is so large 
that data other than the deleting target are also deleted. j 

[0011] 

On the other hand, because personal computer file management currently regards this 512 byte unit as one sector, 
changing this storage capacity unit for file management (also called the file management unit, below) should be 
avoided. Therefore, in accessing one sector which is the file management unit, if attempting to utilize four flash 
memory chips in parallel, the minimum deleting unit becomes larger as a result, and rewriting the sector will require 
deleting four times the capacity of one sector as described earlier. In order to avoid such a situation, if the CPU has 
a 32-bit bus and the flash memory has an 8-bit bus for example, one chip needs to be accessed four times 
sequentially to deal with the 32-bit bus of the CPU. 

[0012] 

However, when continuously accessing four sectors or more, there is no problem even if four chips are accessed 
simultaneously in parallel for each four-sector data and 32 bits from the CPU data bus are accessed simultaneously 
with a one-time access. Namely, if 512 bytes in the first sector are written by 32 bits at a time over 16 times, 128 
(16x8) bytes are dispersed to each step. Next, 512 bytes in the second sector are written by 32 bits at a time over 
16 times. In the same way, 512 bytes in the third sector, and further 512 bytes in the fourth sector are written. At 
this point of time, all the capacity of the minimum deleting units of four chips is filled with data. Therefore, there is 
no problem in deleting this four-sector capacity at once when rewriting this file. 

[0013] 

Thus, simultaneous four-step parallel access is repeated for each four sectors of a file. If there are data left which do 
not fill the last four sectors, other measures will become necessary. 

[0014] 
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If there are three sectors left, because 32 bits of the CPU cannot be divided by 3, they are separated into two sectors 
and one sector for handling. 

[0015] 

If there are two sectors left, or the file is two sectors in size in the first place, 32-bit data from the CPU are divided in 
two, and two chips are simultaneously accessed by 16 bits each at a time. The 512 bytes in the first sector are 
written onto two chips by 16 bits at a time over 32 times, where 256 (32 x 8) bytes are dispersed onto each chip. In 
the same way, the 512 bytes in the second sector are written onto two chips by 16 bits at a time over 32 times. 

[0016] 

If there is one sector left, or the file is one sector in size in the first place, 32-bit data from the CPU are divided into 
four, and one chip'is accessed by 8 bits at a time. The 512 bytes in the one sector are stored in one sector of the chip 
over 64 times. 

[0017] 

As with the above, changing the method of storing data according to the number of continuously accessed sectors 
contributes to an access speed increase and solves the deletion problem accompanying flash memory. Namely, in 
either storing method, because it is guaranteed that only data of the same file are stored inside the minimum deletion 
area of a chip, the problem accompanying the deletion of flash memory is solved. 

[0018] 

Here, although the flash memory is operated synchronously in this invention, delays occur according to the access 
scheme. For this problem, a wait status can be arbitrarily requested to the CPU by using a CPU having a ready 
signal input. CPUs having a ready signal input are popular today. For example, it is installed in all CPUs having 16 
bit processing or higher by Intel Corp., which are the most popular as CPUs mounted in general-use personal 
computers. Because the CPU halts its processing cycle by negating this ready signal, if reading/writing of access 
data has not been completed, this signal can be just negated, and when the access is complete, the CPU resumes 
execution of the processing by asserting it. Because this is a control which becomes possible only when the file 
storage device is in a synchronous operation with the CPU, inputting synchronized clocks to the both at this time to 
make them operate synchronously is indispensable. By these controls, even when the data width per single 
processing is different between the CPU and the flash memory, it can be easily dealt with by letting the CPU wait 
until the data widths are adjusted. 

[0019] 

It is usually impossible in file management to separate anything dealt with in a continuous sector once. Namely, a 
file system can only access in file units. Therefore, when accessing multiple sectors continuously, if multiple chips 
are accessed simultaneously at the time of writing, using the multiple sectors in parallel, the file data as they were 
written can be obtained at the time of reading through the same parallel access. 

[0020] 

As in the above, according this invention, in an information processing device mounted with file storage devices 
having flash memories as its storage media, synchronous control with the system is performed so that the maximum 
performance can be drawn in it access performance which is highly superior to magnetic disk devices. In such a 
case, the CPU is put in a wait status upon necessity by a ready signal input to the system CPU to adjust the timing. 
Even when the system data bus width and the number of access data bits of one chip are different, it becomes 
possible to access at as high a speed as possible. 

[0021] 
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The effect is especially great in reading/writing of large capacity files whose access speed is easily recognized by 
the user, namely in continuous sector accesses. Also, whereas the system data bus width and the number of the 
access data bits of one chip are different according to the purpose, performance, and age, highly-flexible 
configuration is made possible to deal with various things. Also, it can be applied to methods to access memory 
with interleaves to increase the speed. 

[0022] 

According to the configuration equipped with a chaining information, the access procedure from the system is 
simplified to support a high-speed access. Then, the file management itself can be simplified, and simplification of 
control circuit, control program, etc. can be achieved. 

[0023] 

Also, by being equipped with a data distribution function inside a memory element, reduction of peripheral circuits 
and data processing speed increase can be achieved. 

[0024] 

[Embodiments] j 

Embodiments of the present invention are explained hereafter, with reference to the drawings. 

[0025] 1 

First of all, shown in Fig. 1 is a standard personal computer configuration where the flash memory file device of this 
invention is installed. In the figure, 1 is a CPU which in charge of processing data and programs, and its data bus 
width is assumed to be 32 bits. No. 2 is a clock generator which generates a synchronous clock for the whole 
system. No. 3 is a system internal bus containing a data bus, an address bus, memory commands, I/O commands, 
etc. No. 4 is a file control circuit which performs file management and memory control of the flash memory file 
device of this invention. No. 5 is a flash memory array which becomes a storage medium of the flash memory file 
device, where the number of access data bits per chip is 8. no. 6 is a main memory control circuit which 
manages/controls the system main memory, and 7 is DRAM which is the main memory. No. 8 is a peripheral I/O 
bus control circuit, where a display control circuit 9 and a display 10 are connected as one of peripheral I/O devices. 
Listed as other peripheral I/O devices are a communication device 1 1, an external large capacity storage device 12, 
etc. 

[0026] 

Usually, the peripheral I/O bus control circuit contains another clock generation circuit, and these peripheral I/O 
devices operate based on that clock cycle. However, there can be one which is directly connected to the internal 
system bus 3 for speed enhancement and operates in synchronization with the CPU 1. No. 13 is a clock signal 
supplied to each circuit containing the CPU 1 for synchronizing circuits connected to the internal system bus 3. 
Note that it does not need to be entirely the same with the clock supplied to the CPU 1 but can be a divided one 
depending on the circuit as far as it is synchronized. 

[0027] 

No. 14 is a ready control signal input to the CPU 1, where the status indication signals output from individual 
circuits are general-controlled in a ready control circuit 15 and input to the CPU 1. No. 16 is a control circuit of 
input devices for the user of this system to instruct the desired processing, and 17 is an input device. In the figure, 
the input device is assumed to be a keyboard, and its control circuit 16 is assumed to be a keyboard controller 
(KBDC). 

[0028] 
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Next, actions of the system in Fig. 1 are explained. During normal operation, the CPU 1 computes/processes 
programs and data stored in the main memory 7 to execute the process that the user instructed through the innut 
device 17, and displays the result on the display 10. Also, if necessary, it starts up the communication device 1 1 and 
stores a large capacity of data to the large capacity external storage device 12. Then, in retrieving or storing files it 
operates the flash memory file device consisting of the file control circuit 4 and the flash memory 5 When booti'na 
up the system also, the system program is loaded from here. During these operations, synchronous operations are 
performed by the clock 13 generated by the clock generator 2, and if there occurs a need for a certain circuit to 
request a stand-by to the CPU 1, that circuit request a CPU stand-by to the ready control circuit 15 and it is 
conveyed to the CPU 1 by negating the ready signal 14. The CPU 1 will continue to stand by until the ready signal 
14 is asserted again. At this time, the file control circuit 4 can perform a control of increasing/decreasing the CPU 
stand-by time by the number of files requested to the CPU 1. This mechanism is explained with reference to Fig. 2. 

[0029] 

Figure 2 is a drawing to explain the internal configuration of the flash memory file device. In the figure, 3, 4 5 and 
13 are the same as those in Fig. 1, and the following are internal components of the file control circuit 4 ' No 21 is a 
register group which performs interfacing with the system bus 3, no. 22 is a status register for reporting the status of 
the file control circuit 4 to the CPU 1, 23 is a register for setting the starting sector number to access, 24 is a register 

V ™? 8 8 SeC, ° r " Umber t0 3CCesS ' 25 is a command re g jster w h«ch instructs the processing requested by 

the CPU 1 as a command code, and 26 is a data register which becomes a window of data give and take with the 
system bus. 27 is a controller which takes a general control of internal controls of the file control circuit 4 which is 
ideally a programmable, intelligent LSI such as a one-chip microcomputer. No. 28 is a control circuit which 
performs control of the flash memory 5 which is a storage medium, 29 is a data control circuit which performs 
control of data to read from or write to the flash memory. No. 30 is a DMA control circuit for performing memory 
access at high speed, and the system clock signal 13 is input to this circuit. No. 31 is a status indication signal 
output to the ready control circuit 15, no. 32 is a local bus inside this flash memory file device, and 33 is a control 
signal and address for accessing the flash memory. 

[0030] 

Next, actions of the flash memory file device in Fig. 2 are explained. When a necessity to access with the flash 
memory file device arises, the CPU 1 performs the access via the system bus 3. In order to do so, first the content of 
the status register 22 is read out to check whether it is in an accessible status or not. Then, the sector to access next 
is set to the starting sector register 23 and ending sector register 24. Then, it writes the command code (read or 
write) of the requested access to the command register 25. Then, the status register 22 is read again and if the 
access is possible, data are written to or read from the data register 26. 

[0031] 

At this time, the controller 27 manages these interface registers 21 to respond to requests from the CPU 1 Namely 
it reads the starting sector register 23, ending sector register 24, and command register 25, grasps the access content 
ot the flash memory 5, write a code indicating the current status to the status register 22, and reports to the CPU 1 . 

[0032] 

Because it is expected that the controller 27 is too slow in its operation speed to perform directly flash memory 
access for responding to the access requests from the CPU 1, the configuration is made so that the DMA control 
circuit 30 performs flash memory access at high speed and performs give and take of data with the system bus 3 
The controller 27 will perform setting the access content, starting up the DMA, etc. to the DMA control circuit 30 
and the memory control circuit 28 for that purpose. 

[0033] 

The DMA control circuit 30 performs address generation and timing generation for performing the DMA, and the 
memory control circuit 28 generates access signals follow that timing. The flash memory 5 performs give and take 
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of data with the data control circuit by these input signals. The data control circuit 29 performs data generation 
according to the number of sectors to access. 

[0034] 

For example, in the case of write access of one sector, data sent by one-time access from the system bus 3 are 
adjusted to the number of writing bits of one chip of flash memory. In this embodiment, because the data bus width 
of the system bus 3 is set to 32 bits, 32 bits of data are obtained through a transfer by one access. Then, because the 
data width of one chip of flash memory is set to 8 bits, the sent data are divided into four to write to the flash 
memory 5. Therefore, the processing of dividing 32-bit data into four 8-bit data is performed by the data control 
circuit 29 using a latch circuit. Also, in the case of read access of one sector on the contrary, the flash memory 5 is 
read accessed four times to prepare 32-bit data for one bus transfer. The wait time of the system bus occurring at 
this time is generated by a stand-by request to the CPU 1 by a status indication signal 31 generated by the data 
control circuit 29. 

[0035] 

On the other hand, in the case of access to multiple sectors, the data control circuit 29 adjusts the data to latch for 
increasing the access speed and execute it normally. For example, if it is a continuous read access of four sectors, 
because 32-bit data are completed by simultaneously reading four chips of 8-bit access flash memory 5, [the wait 
time of the system bus 3 can be greatly reduced. Note that four-chip simultaneous write access needs to be 
performed at the time of writing to the flash memory 5. Otherwise, the order of data will come to differ and the file 
data will become abnormal. Note that because it is common to perform management with file units in (systems 
dealing with file storage devices, it is usual to read-access the same number of sectors with the number of sectors 
when they were written, and if the access schemes according to the number of sectors are made entirely the same 
between writing and reading, there will be no need to record the information. Namely, if it is an access scheme of 
continuous writing of five sectors, the first four sectors are simultaneously written to four chips in parallel, and the 
remaining one sector is divided in four to one chip, adopted in both reading and writing for example, and normal file 
data can always be accessed. Here, to make sure, information on the data storing scheme may be recorded in data in 
sector units stored in the flash memory 5. As its record location, if there exists a redundant area other than the data 
storing area of the flash memory, storing there is appropriate, and if there is no redundant area, a separate storing 
area is installed for recording. 

[0036] 

A continuous access of six sectors is dealt with a parallel access of four sectors and a parallel access of two sectors. 
[0037] 

Next, these access signals and data control method are explained in even more detail with reference to Fig. 3. 
[0038] 

Shown in Fig. 3 is a configuration where the bit width of the system bus is set to 32 bits, and that of the flash 
memory to 8 bits. In the figure, numbers that already appeared before are identical to those explained so far. Newly, 
41 is a counter for generating addresses of the DMA control circuit 30, where the system clock 13 and I/O access' 
(command) signals or memory access (command) signals of the system bus 3 are input and counting up is performed 
in synchronization with this. No. 42 is a start-up register for DMA control where the local bus 32 of the controller 
27 is connected, and a desired DMA transfer can be started by writing a code to this register. No. 43 is a sector 
register which is connected to the local bus 32, too, and DMA transfer of an arbitrary sector number can be 
performed by writing the sector number to access. In the actual operation, written value of this sector number is 
input to the memory control circuit 28 which is used for generating the upper-order address of the flash memory and 
chip select signal. No. 44 is a timing circuit which generates a timing signal for synchronizing in each control 
circuit at DMA transfer. No. 45 is a memory address generated by the memory control circuit 28 based on values of 
the counter 41 and sector register 43. No. 46 is a memory control signal generated by generation of the memory 
address 45. 51, 52, 53, and 54 are data latches of one byte (8 bits) each, constituting data latches of four bytes (32 
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bits) for data width conversion between 32-bit data and 8-bit data. When data of the system bus 3 are denoted as 
D0-D31, the latch 51 latches DO-D7, the latch 52 D8-D15, the latch 53 DI6-D23, and the latch 54 D24-D31, 
respectively. 55 is a latch signal generation circuit for these data latches. 56 is a data control setting register which 
is connected with the local bus 32 and sets data width and data order. In this embodiment, generation of a latch 
signal and its timing are instructed to the latch signal generation circuit 55 by setting one of "1" "2", and "4" to this 
data control setting register 56 as the number of continuous access sectors at read access. Then, latch signals input 
to data latches 51, 52, 53, and 54 are 57, 58, 59, and 60, respectively. For example, if "1" is set, latch signals 57, 58, 
59, and 60 are output sequentially one by one, and data from one chip of flash memory are accessed four times to 
generate 32-bit data which are output to the system bus 3. Also, if "2" is set, latch signals 57 arid 58 are output 
simultaneously and afterwards latch signals 59 and 60 are output simultaneously, which are performed alternately, 
and data from two chips of flash memory are accessed twice each to generate 32-bit data which are output to the 
system bus 3. Also, if "4" is set, latch signals 57, 58, 59, and 60 are output simultaneously, and data from four chips 
of flash memory are accessed only once to generate 32-bit data which are output to the system bus 3. 

[0039] 

On the other hand, during a write access, latch signals are always sent to data latches 51, 52, 53, and 54 
simultaneously to latch 32-bit data from the system at once. No. 61 is a data distribution circuit which distributes 
data stored in data latches 51, 52, 53, and 54 or data from the memory 5. No. 62 is a 32-bit data bus connecting the 
flash memory 5 and the data distribution circuit 61. No. 63 is a read/write signal for determining the data direction 
of the data distribution circuit 61, which should better receive supply from the command register 25 of the interface 
register 21. The data distribution circuit 61 is made as a bidirectional buffer, where one side is connected to data 
latches 51, 52, 53, and 54, and the other side to the flash memory 5. On the flash memory 5 side, the input is in 32 
bits, and all the chips of the flash memory 5 are divided into four groups, which are divided into separate bit groups 
(Bits 0-7), (Bits 8-15), (Bits 16-23), and (Bits 24-31), and input as 32 bits in total. Then, the direction is 
determined by whether it is read or write, and partitioning of each data are determined by the setting content of the 
data control setting register 56. 

[0040] 

Specific explanations are given on this distribution of data using Fig. 12, Fig. 13, and Fig. 14. These figures show 
data distribution examples of the data distribution circuit 61 for different values set to the data control setting 
register 56. Figure 12 shows data distribution when the number of continuous access sectors is 1, Fig. 13 when the 
number of continuous access sectors is 2, and Fig. 14 when the number of continuous access sectors is 4, 
respectively, and there are four kinds of data distributions in each case depending on which of the four memory 
groups to access. Also, read and write are distinguished. When the number of continuous access sectors is 1, four 
system cycles make one access, when the number of continuous access sectors is 2, two system cycles make one 
access, and when the number of continuous access sectors is 4, one system cycle makes one access. 

[0041] 

When the number of continuous access sectors is 1, classification into four kinds is made depending on where in the 
divided memory to access, and when the number of continuous access sectors is 2 or 4, classification into four kinds 
again is made depending on which memory group is set as the starting point. Namely, the starring point can be 
adequately determined depending on how the memory is used, and by doing so the bias of used memory groups can 
be prevented. For example, although the data distribution method can be simplified if the memory group 1 is always 
set as the starting point, it is expected that the ratio of usage of the memory group 1 becomes high and there occur 
biases in both the amount of use and the frequency of use. If a bias occurs, one memory group eventually becomes 
unavailable, making is impossible to perform high-speed write access when the number of continuous sectors is 4. 
Therefore, it is made possible to set the starting point in any memory group. 

[0042] 

Note that although in reading when the number of continuous sectors is 1 or 2, data connection lines in the 
distribution circuit are made separate for each cycle in the figure, because the latch signal is not output to other than 
the target latch, the connection line may be shared instead of separating for each cycle. Namely, in reading of A 
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where the number of continuous sectors is 1 (Fig. 12), whereas the distribution is performed in a sequential cycle 
with latch 1 - memory group 1 , latch 2 - memory group 1 , latch 3 - memory group I , and latch 4 - memory group 1 , 
connection lines to all the latches may be connected to 1 of the memory group in all cycles. This is because even if 
data lines are connected, there is no influence if no latch signal is output. 

[0043] 

More specifically, referring to Fig. 12 in the write access of one sector for example, one byte connected one of the 
access target flash memory groups among the 32-bit data bus 62 is written to the flash memory with the data latch 
51 at the first rime, the data latch 52 at the second time, the data latch 53 at the third time, and the data latch 54 at 
the fourth time, which is repeated from 51 sequentially. In the read access, one cycle of data are distributed to each 
latch by the latch signal. 

[0044] 

In the write access of two sectors, namely, if it is a write with a data width of 2 bytes, from Fig. 13, as 2-byte data 
connected to the corresponding two memory groups among the 32-bit data bus 62, data are received from the data 
latches 51 and 52 at the first access, 53 and 54 at the second access, and distributed alternately afterwards. On the 
other hand, in the read access the order becomes reversed, and data are distributed from the corresponding two 
memory groups to the data latches 51 and 52 in the first access, 53 and 54 in the second access, and this is repeated. 

[0045] 

i 

In the write access of four sectors, namely, if it is a write with a data width of 4 bytes, the buffer direction becomes 
the one from the data latch to the flash memory 5, the 32-bit data bus 62 is connected to the data latches 5 1, 52, 53, 
and 54 sequentially from its top memory group, and 32-bit access is completed by one-cycle access. In reading, the 
direction becomes the opposite. j 

[0046] 

In order to perform the actions, the controller 27 needs to set appropriate values to the registers explained so far 
before starting up the DMA control circuit 30. 

[0047] 

When multiple memory groups are accessed simultaneously in order to increase the speed as described earlier, 
addresses given to the individual memory groups are investigated below referring to Fig. 5. 

[0048] 

In Fig. 5, 81-84 indicates memory groups 1-4, respectively. The same figure (1) shows a state where a certain 
amount of file writing has been performed, and the same figure (2) shows a state where a certain file has been 
updated and its file size has increased. The data code (nwi) shown in the figure indicates a file number m and a 
sector number n in each file. For example, (3-2) indicates the second sector of the file number 3. Note that this 
figure shows area (having a capacity of one sector or more) of which memory group is used how as a whole, and in 
actuality, at a continuous access of two sectors or more, instead of content of only a single sector being stored in a 
one-sector capacity area of each memory group, contents of multiple sectors are stored dispersed. This point will be 
described in detail later in the explanation of file management. 

[0049] 

In Fig. 5(1), in the access of file number 1 (all sectors coded as 1-n), in a simultaneous access from 1-1 to 1-4, 
because these are arranged in the same line, same address can be given to these memory groups. However, in file 
number 2, if 2-1 to 2-4 are used for a simultaneous access, the memory group 4 needs to be given a different address 
from other memory groups. This means that the same number of address buses with the number of memories need 
to be installed. Or, there needs to be some way to give different addresses to the memory groups. In order to avoid 



FH 008719 



( 1 3 > Pat Open Hei 6-266596 



this, an access scheme needs to be taken in accesses of file number 2 that 2-1 is accessed alone 2-2 and 2-3 are 
simultaneously accessed, and 2-4 is accessed alone again. However, this will generate a waste 'in increasing the 
speed. Then, an example of configuration for giving different addresses is explained using Fig. 9. 

[0050] 

Figure 9 is an example of configuring an address generation circuit inside the memory control circuit 28 when the 
number of memory groups is set to 4. In the figure, 201-204 are four memory groups constituting the Hash memory 
5, where 201 is a first memory group a, 202 is a second memory group b, 203 is a third memory group c, and 204 is 
a fourth memory group d. 205 is a latch circuit b of the high-order address given to the memory group b, 206 is a 
latch circuit c giving to the memory group c, and 207 is a latch circuit d giving to the memory group d. 208 is the 
address bus of the memory control circuit 28 (corresponding to 45 in Fig. 3), and 209 is the low-order address of the 
address bus 208. The number of its address bits is set to the number of address bits which corresponds to that for 
accessing the storage capacity of the data deletion minimum unit or the minimum unit for file management of the 
flash memory chip. For example, if the data deletion minimum unit is 512 bytes, it becomes 9 bits. Only when the 
data deletion minimum unit of the flash memory chip is smaller than the minimum unit for file management, it is 
effective to make it the number of address bits which corresponds to the minimum unit for file management. 210 is 
the high-order address of the address bus 208 excluding the low-order address 209. Note that even higher-order 
address which is unnecessary in accessing the memory groups is removed. No. 21 1 is a high-order address stored in 
the address latch b for accessing the memory group b, 212 is a high-order address stored in the address latch c for 
accessing the memory group c, and 213 is a high-order address stored in the address latch d for accessing the 
memory group d. No. 214 is a memory control signal for the memory group a201, 215 is a memory control signal 
for the memory group b202, 216 is a memory control signal for the memory group c203, and 217 is a memory 
control signal for the memory group d204. 

[0051] 

In the configuration of Fig. 9, when accessing the memory group a to the memory group d simultaneously, high- 
order addresses to access these memory groups are written in advance to the address latches 205-207. Then, when 
performing the access, because the low-order address 210 is common to all the memory groups, the address bus 
supplies the address for accessing only the memory group a, and memory groups other than the memory group a are 
accessed through the high-order addresses from the corresponding address latch circuit. Note that access control is 
entrusted to the memory control signals 214-217, and if access is only to the memory group a and the memory 
group b for example, it is arranged so that only the memory control signals 214 and 215 become active. Also, in 
accessing only the memory group d for example, unless the memory control signal 21 is set active, the memory 
group a may be give any address without a problem. By this means, it becomes possible to give different addresses 
to individual memory groups, only if the memory groups are dispersed into 4, data of the same file stored in 
locations at physically different addresses can be accessed simultaneously, enhancing the contribution of speed 
increase. In the configuration of Fig. 9, the address latch of the memory group a can be omitted. Of course, if it is 
effective to install an address latch also for the memory group a, it may be done so. 

[0052] 

According to the above embodiment, the CPU 1 can perform read/write access of a desired sector at high speed by 
performing simple specifications to relatively a small number of registers. Also, the file controller is made as a one- 
chip microcomputer, where fine control can be instructed by software, and data transfer can be performed at high 
speed by loading a DMA transfer control circuit even if the one-chip microcomputer can only perform slower 
operations than the system. However, if the operation speed of the one-chip microcomputer is high enough to 
perform high-speed operations for the system, the DMA control circuit is not necessary, and a configuration where 
all data transfers are performed by the one-chip microcomputer can also be considered. 

[0053] 

Also, although an explanation has been given in this embodiment assuming the data buses are 32 bits for the system 
and 8 bits for the flash memory, also for the CPU 1 of 16-bit operation, CPUs of 64-bit operation, and a flash 
memory of 16-bit I/O, adjustment to other data widths can be easily performed by changing the number of data 
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latches, configuration of the data control setting register, and control programs of controllers. The concrete example 
is shown in , Fig. 15. Shown in Fig. 15 are concrete numerical values of hardware configuration in a combination of 
individual bit widths. The horizontal configuration of the figure is the number of data bits of the flash memory 
where 4 bit, 8 bit, 16 bit, and 32 bit are listed as examples. The vertical configuration shows the system data width' 
where 8 bit for simple information equipment, 16 bit and 32 bit which are the mainstream of the present personal' 
computers, and 4 bit and 128 bit for the future personal computers and high-performance computers are listed as 
examples. Also, the data distribution circuit listed as a hardware configuration is, if explained using the data 
distribution circuit 61 of the embodiment, shown in the number of bits of one circle x the number of circles in the 
figure. Connection of each circle can be shown in the same idea with Fig. 12 - Fig. 14. While the number of 
latches is increase or decrease of the number of latches 51-54 in the embodiment, if the number of memory data bits 
is larger than the system data width, the latch location will be configured in the data distribution circuit memory side 
The number of memory groups indicates the number of divisions of the memory which is divided in four in the 
embodiment. 

[0054] 

Note that the number of distribution of the data distribution circuit, the number of latches, and the number of 
memory groups are lower limit numbers including this embodiment, and if there is some room in the circuit scale 
the number of terminals, etc., increasing them will make a more effective system configuration. That is because 
increasing the number of memory groups gives more room in selecting memory for storing data, which carl prevent 
biases of memory usage and frequency of use. Also, because the number of memories to access in parallel can be 
increased speed increase can be further progressed. Especially, when the system data width and the number of 
memory data bits are equal to each other or the number of memory data bite is larger, although there is no effect of 
adjusting the data bus widths at all as described in the embodiment, multiple memory chips can be simultaneously 
accessed and speed increase by the so-called interleave method can be realized. In this case, at the same time with 
increasing the number of memory groups, the number of memory data distributions in the data distribution circuit 
and the number of latches need to be increased. 

I 

[0055] 

Note that although explained in this embodiment is that the flash memory can follow data transfer from the system 
to do so it is preferable that a write buffer be installed inside the flash memory. If it is a flash memory which can 
perform writing at high speed in the future, this kind of write buffer will become unnecessary. If no write buffer is 
contained in the flash memory, a write buffer can be installed between the flash memory and the data control circuit 
Then, at each write access, writing is performed not directly to the flash memory but first to the write buffer and 
after data transfer from the system is complete, writing is performed from the write buffer to the flash memory The 
configuration diagram of an embodiment of this case is shown in Fig. 4. 

[0056] 

In Fig. 4, numbers which already appeared before are the same with those explained so far. As new ones 71 is a 
data selector which switches connection with the data distribution circuit 61 depending on whether the access is read 
or write, 72 is a write buffer of 32-bit width which temporarily stores write data, and 73 is a read/write signal for 
switching the data selector 71, where a part of data of the command register 25 is better to be input. If the access is 
write, the data distribution circuit 61 is connected with the write buffer, write data are stored in the write buffer and 
the controller performs writing to the flash after data transfer from the system. If it is read, the data distribution 
circuit 61 is connected directly to the flash memory, and the same operation with the read access in Fig. 3 describe 
above is executed. By making it the configuration, even using a flash memory which does not contain a write buffer 
and has a slow writing, high-speed accesses become possible, seen from the system. 

[0057] 

Next, an embodiment of file management is explained with Fig. 5 as an example. Although embodiments of 
hardware have been explained so far, how to store actually to the flash memory is described below. This operation 
is basically performed by the system CPU, system program, and the controller of the flash memory files, where the 
central issue is operation by software. In the explanation using Fig. 5, instead of the content of the software itself, 
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shown is how unit capacity area (for one sector) of each memory group of the flash memory as the whole is assigned 
to a sector of a file as a result of the operation. For each sector of a file, unit capacity area is secured in sequential 
memory groups. For continuous sectors of four or more, one unit capacity area of sequential memory groups 1-4 
are assigned to the four sectors (1-1-1-4 in the figure for example). Note that data in each sector are actually stored 
dispersed in four unit capacity areas. To two sectors (1-5-1-6 in the figure for example), unit capacity areas of two 
memory groups are assigned. In this case also, data in each sector are stored dispersed in two unit capacity areas. 
Assigned to the last sector 1-7 of file 1 is a unit capacity area of a single memory group. 

[0058] 

Here, an even more detailed explanation is given on dispersed storing of two sectors and four sectors using Fig. 10 
and Fig. 1 1. Shown in Fig. 10 is an example of 4-byte simultaneous write, and Fig. 11 is an example of 2-byte 
simultaneous write. In the same ways as the above, it is assumed that the host system bus is 32 bits, and that the 
memory access width of one memory group is 8 bits. 

[0059] 

Shown in Fig. 10 is an example of 4-sector simultaneous write to the memory groups a-d. In the figure, indicated 
with 21 1 is data from the system bus, which are sent with 32 bits (4 bytes) as a unit. Indicated with 222-225 are 
sequential numbers of 8-bit (1-byte) unit data, 222 is the first byte data, 223 is the second byte data, 224 is the third 
byte data, and 225 is the fourth byte data. Following them, data up to the 2048th byte are continuously sent as those 
for 4 sectors. Actually, because of the 32-bit bus, from the first byte to the fourth byte are simultaneously received, 
and the following are the same. Nos. 51-54 are data latches for temporary storage of data shown in Fig. 3. 

[0060] 

Because of being simultaneously written 4 bytes at a time, after storing 32 bits, namely 4 bytes, simultaneously to 
the data latches 51-54, each byte is dispersed to the memory groups a-d and is written one byte each. For the next 
32-bit data, each byte is written to the following parts of the memory groups a-d. In this way, when 512 bytes 
corresponding to 1 sector are written, subsequently data for the second sector are written by 4 bytes at a time to the 
following parts of the memory groups a-d in the same way. Although Fig. 5 is shown for convenience as if each 
sector is assigned to a specific memory group, as in the above explanation, actually data in each sector are not stored 
only in a specific memory group but written dispersed to the memory groups a-d. Note that it is true that data of the 
whole 4 sectors are stored in an area of 4-sector capacity in the memory groups a-d. 

[0061] 

Shown in Fig. 11 is an example of 2-byte simultaneous write to the memory group a and the memory group b. 
[0062] 

Because of being a simultaneously written 2 bytes at a time, after storing 32 bits, namely 4 bytes, simultaneously to 
the data latches 51-54, these are divided in two by 2 bytes each, the first half 2 bytes are first written to the memory 
group a and the memory group b by 1 byte each, next the latter half 2 bytes are written to the memory group a and 
the memory group b by 1 byte each. In this way, when 512 bytes corresponding to 1 sector are written, 
subsequently data for the second sector are written from the first byte to the following parts of the memory groups a 
and b in the same way. In this case also, the first sector is not stored only to a specific memory group but written 
dispersed to the memory groups a and b, and in the same way, the second sector is written dispersed to the memory 
groups a and b following the first sector. 

[0063] 

Although writing to a single sector is not shown, individual byte data of the data latches 51-54 are simultaneously 
stored to a certain memory group sequentially in this case. Only in this case, data of one sector are stored to a 
specific memory group without being dispersed. 
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[0064] 



As can be seen from the above, the important thing is that there is no data mixed from different files in the area of 
the minimum deletion unit (512 bytes corresponding to one-sector capacity here) of a flash memory element as a 
result of the above operations. By this guarantee, it becomes possible to achieve high-speed file data storing by 
writing multiple bytes simultaneously in parallel as effectively utilizing the storage area of memory when rewriting 
a file without deleting data of other files. 



[0065] 

As stated above, Fig. 5(1) shows a state where a certain degree of file writing has been performed, Fig. 5 (2) a state 
where a certain file has been updated and the file size has increased afterwards. In Fig. 5(1), storing is performed so 
that different memories are assigned in the order of file numbers to be stored and the order of sector numbers. In 
principle, they are packed to leave no space so that there will be no waste in terms of management. 

[0066] 

As shown in Fig. 5(1), if file sectors are stored in memory groups by packing sequentially and continuously so that 
no vacant space occurs, when a file size has increased by updating the file, there occurs cases as shown in Fig. 5 (2) 
where continuous storing in terms of physical storage location is impossible. Even in such a case, storing is 
performed so that the order of memory groups becomes continuous. Namely, if the file number 4 is taken as an 
example, while five sectors from 4-1 to 4-5 are stored in (1), if two sectors are added in (2), because 4-1 is started 
from the memory group 3, areas in the memory groups 2 and 3 are secured for the increased portion of 4-6 fend 4-7. 
When writing a file whose number of sectors is increased, 4-5 and 4-6 are treated as 2-sector continuous sectors at 
this time, and 4-7 is treated as a single sector. Namely, added sectors also receives a treatment as continuous sectors 
together with already-stored sectors. In order to perform smoothly these storing and reading out in file management, 
it is believed to be more appropriate as a hardware configuration that specification of access sectors from the system 
should be the starring sector and the number of sectors and grasping the physical storage locations should be 
performed inside the file system. Namely, whereas specifying access files from the system should be simplified as 
much as possible for the speed increase, if physical locations are scattered, specifying the physical locations 
becomes complicated. Therefore, the ending sector 24 shown in Fig. 2 should be removed in this sense. Then, by 
storing information indicating file chaining in an redundant area of the memory to store information other than data 
if it exists, or in another storage means if it does not exist, because if the file starting number is specified, all the 
physical locations of sector numbers following it become clear by chaining, a continuous access becomes possible. 

[0067] 

Shown in Fig. 6 is an example of chaining information. In the figure, 85 is file data stored in memory, which are 
data of file number 4 and sector number 5. 85 is the data of file number 4 and sector number 6 that follow them 
And 87 is data of file number 4 and sector number 7 that further follow them. Note that although these data are 
arranged in the order of the sector numbers, they may be mixed in the actual storage state. Namely, data may be 
stored scrambled by accessing multiple chips simultaneously through a continuous sector access. However, because 
numbering of data storage by byte is necessary even in such a case, sector numbers are very important.' 88 is a 
physical address indicating the physical location on memory where the file data 85 are stored, where the number "3" 
on the left side is the memory group number, the number "5" on the right side is the address in that memory group. 
89 and 90 are physical addresses of the file data 86 and the file data 87 in the same way. 91 is chaining information 
indicating the physical address where the next sector of the file data 85 are stored, and because the file data 85 are 
data of file number 4 and sector number 5, the chaining information 91 indicates the physical address where data of 
file number 4 and sector number 6 are stored. The number on the left side is the memory group number, and the one 
on the right side is the address in the memory group. In the same way, chaining information 92 indicates the 
physical address where data of file number 4 and sector number 7 are stored, and chaining information 93 indicates 
a case where the next sector does not exist. Namely, it can be told that the file of file number 4 ends with 7 sectors. 
If this chaining information is attached with file data, the system CPU does not have to grasp the physical location 
of file storage but can take a scheme of simply accessing the file itself. Then, by the controller of file control 
performing physical accessing of memory as referring to the chaining information, even with a file whose physical 
storage locations are not continuous but scattered, a continuous access becomes possible. In that case, a 
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configuration to input different addresses for simultaneous access of different memory groups is necessary Note 
that as stated earlier in Fig. 9, low-order address for the one-sector access can be shared, necessity is only for the 
high-order address for more than that. According to embodiments using chaining information above access 
specification from the system can be simplified to enable the execution with smaller amount of information. ' 

[0068] 

Next, an explanation is given on an embodiment of embedding various kinds of functions in a memory element 
itself. 

(0069] 

Figure 7 is a configuration diagram of a memory element where multiple memory chips are contained in a package 
and an additional circuit is installed. In the figure, 101 is a memory package, 102-105 are memory chips having the 
same function 106-109 are input/output data terminals of the memory package 101, each of which can perform data 
input/output of one memory chip. For example, if the memory chip 102 has 8-bit data input/output, 106-109 come 
to have 8 bits x 4 = 32 bits of data input/output terminals in total. No. 1 10 is a signal input terminal which specifies 
the path to connect these memory chips with input/output terminals, 111 is a specification signal, and 112 is a 
connection path setting circuit. A user of this memory 101 executes an access after setting 109 with the signal input 
terminal 1 10 from the data input/output terminal 106. It is considered as an example that this setting is selected 
from connection paths such as those in Fig. 12, Fig. 13, and Fig. 14 stated earlier. In the memory 101 set data 
connection is sent as the specification signal 111 to the connection path setting circuit 1 12, the connection setting 
circuit 112 connects the memory chips 102-105 with the data input/output terminals 106-109 according to the 
setting, and realizes connection of data in the memory chip with the desired data bus. 

[0070] 

Figure 8 is a configuration example of a memory element which performs setting of data connection from a user by 
a command input. In the figure, 1 13 is a command control circuit which creates the specification signal 1 1 1 from a 
register of the command set value and its set value. 1 14 is a data line where the user set the command set value 
using a part of the data input/output terminal. Others are the same as those with the same numbers in Fig 7 A user 
selects a data connection path with Fig. 12, Fig. 13, and Fig. 14 as an example, sets as a command code from a part 
of data bus 1 14 to the command control circuit 1 13, and sends the specification signal 1 1 1 which corresponds to the 
connection path setting circuit 1 12 from the command code set in the command control circuit 1 13 Below is the 
same as the explanation of Fig. 7. According to this embodiment by Fig. 7 and Fig. 8, another embodiment 
explained so far can be realized as a memory element, and there is an efficacy that reduction of peripheral circuits 
can be achieved. Note that although in this embodiment multiple chips and control circuits are to be loaded in a 
memory package, by uniting these into one chip, miniaturization and speed increase can be promoted. 

[0071] 

[Efficacy of the Invention] 

According to the present invention, it becomes possible in a Hash memory device to achieve high-speed file data 
storing by writing multiple bytes simultaneously in parallel as effectively utilizing the storage area of the memory 
when rewriting a file without deleting the data of other files. 
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[Brief Explanation of the Drawings] 

[Fig. 1] A block diagram showing a system configuration which realizes this invention. 

[Fig. 2] A block diagram showing the configuration of an embodiment of the flash memory file device. 

[Fig. 3] A block diagram of the main section for explaining actions of the embodiment. 

[Fig. 4] An explanatory drawing showing data control when a slow-writing flash memory chip is used in the 
embodiment. 

[Fig. 5] An explanatory drawing of an execution example of storing files to the memory in the embodiment. 

[Fig. 6] An explanatory drawing of an execution example of storing chaining information in another embodiment of 
this invention. 

[Fig. 7] An explanatory drawing of a memory configuration example where the data distribution function by the 
signal terminal input specification is installed in the memory element. 

[Fig. 8] An explanatory drawing of a memory configuration example where the data distribution function by the 
command setting input specification is installed in the memory element. > 

[Fig. 9] An explanatory drawing of address connection of the memory groups in the embodiment. j 

[Fig. 10] An explanatory drawing of actions at 4-byte simultaneous write in the embodiment. 

[Fig. 1 1] An explanatory drawing of actions at 2-byte simultaneous write in the embodiment, (system bus 32 bit,) 

[Fig. 12] An explanatory drawing of data distribution at memory 1-chip simultaneous access in the embodiment. 

[Fig. 13] An explanatory drawing of data distribution at memory 2-chip simultaneous access in the embodiment. 

[Fig. 14] An explanatory drawing of data distribution at memory 4-chip simultaneous access in the embodiment. 

[Fig. 15] An explanatory drawing of hardware configurations in various configurations of the system bus and the 
memory data bus. 



[Explanations of the Codes] 

I: CPU, 2: Clock generation circuit, 3: System bus, 4: File control circuit, 5: Flash memory, 6: Main memory 
control circuit, 7: Main memory, 8: External I/O control circuit, 9: Display control circuit, 11: Communication 
circuit, 12: Large capacity external storage device, 13: System clock, 15: Ready control circuit, 16: KBDC, 21: I/F 
register, 22: Status register, 23: Starting sector register, 24: Ending sector register, 25: Command register, 26: Data 
register, 27: Controller, 28: Memory control circuit, 29: Data control circuit, 30: DMA control circuit, 31: Status 
indication signal, 32: Local bus, 41: Counter, 42: Startup register, 43: Sector register, 44: Timing control circuit, 45: 
Address, 46: Control, 51: Latch circuit, 52: Latch circuit, 53: Latch circuit, 54: Latch circuit, 55: Latch circuit 
generation circuit, 56: Data control setting register, 61: Data distribution circuit, 63: Read/write signal, 71: Data 
switching circuit, 72: Write buffer, 73: R/W signal, 85: Data (4-5), 86: Data (4-6), 87: Data (4-7), 91: Chaining 
information, 101: Memory package, 1 10: Specification signal input terminal, 1 12: Connection path setting circuit, 
1 13: Command control circuit, 201: Memory group a, 202: Memory group b, 203: Memory group c, 204: Memory 
group d, 205: Address latch b, 206: Address latch c, 207: Address latch d, 208: Address bus, 209: Low-order address, 
210: High-order address, 2 1 4-2 1 7: Memory control signals. 
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(54) [Title of the Invention] Flash memory file storage device and information processor. 

(57) [Abstract] (Modifications exist.) 

[Construction] 

In a file storage device using Hash memory elements whose minimum deleting unit is larger than X bits and access 
width is x bits (x = X/p: p is an integer equal to or greater than 2) through an X-bit data bus, it is equipped with a 
flash memory device 5 consisting of p sets of flash memory element groups accessible simultaneously, a dividing 
means 51-54 which divide data on the data bus into at least p parts, a data distributing means 61 which has at least a 
first function to make p pieces of x-bit data correspond to one set of the flash memory element groups and a second 
function to make each of the p pieces of x-bit data correspond to another set of the flash memory element groups, 
and a control means 56 which controls the data distribution means 61 so that the first and second functions are 
switched according to the number of storage capacity units for file management of the access target File. 

[Efficacy] 

It becomes possible to read multiple bytes simultaneously in parallel while effectively utilizing the memory 1 area. 
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[Scope of Patent Claims] 
[Claim 1] 

In a flash memory file storage device which is a file storage device storing data through an X-bit data bus and which 
uses flash memory elements whose minimum deleting unit is larger than X bits and the access width is x bits (x = 
X/p: p is an integer equal to or greater than 2), a flash memory file storage device characterized by being equipped 
with a flash memory device consisting of p sets of flash memory element groups accessible simultaneously, a 
dividing means which divide data on the X-bit data bus into at least p parts, a data distributing means which has at 
least a first function to make p pieces of x-bit data obtained by the division correspond to one set of the flash 
memory element groups and a second function to make each of the p pieces of x-bit data correspond to another set 
of the flash memory element groups, and a control means which controls the data distribution means so that the first 
and second functions are switched according to the number of storage capacity units for file management of the 
access target file. 

[Claim 2] 

The flash memory file storage device described in Claim 1 characterized by the fact that the control means controls 
the data distribution means so that data of different files do not coexist in the memory area of the minimum deleting 
unit of the flash memory* element. 

[Claim 3] 

The flash memory file storage device described in the Claim 1 or 2 characterized by the fact that the control means 
controls the data distribution means so that the second function is selected for data of continuous p pieces of storage 
capacity units in the file, and that the first function is selected for data of one storage capacity unit 

[Claim 4] 

The flash memory file storage device described in the Claim 1 or 2 characterized by the fact that the storage capacity 
unit and the minimum deleting unit of the flash memory element are equal to each other. 

[Claim 5] 

In an information processing device having as its components a central computing/processing means which 
processes programs and data, a clock oscillation means which drives the central computing/processing means, a file 
storage means having flash memory as its storage medium, a file storage control means which controls access of the 
flash memory of the file storage means, an information processing device loaded with a flash memory file storage 
device characterized by the fact that the same signal or synchronized signal with clock signal generated by the clock 
oscillation means is input to the file storage control means, and that the central computing/processing means and the 
file storage control means perform synchronized actions to send/receive file data. 

[Claim 6] 

The information processing device described in the Claim 5 characterized by the fact that when the one-time data 
access width is different between the central computing'processing means and the file storage means, the file storage 
control means is equipped with a means to output a status indication signal indicating whether file data are being 
processed or the processing is complete, the central computing'processing means has a function wherein it receives 
the status indication signal if it indicates that it is in process, it halts the process until the processing is complete, the 
file storage control means has a data bit width control means which adjust the number of data bits dealt with by the 
file storage means to the processing data bit width of the central computing/processing device, the data bit width 
control means shows to the central computing^processing means that processing is taking place using the status 
indication signal, and allows it to stand by during the period necessary for adjusting the data bit widths, and 
performs data exchange by adjusting the processing data width of both. 
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[Claim 7j 

The information processing device described in the Claim 6 characterized by the fact that the file storage means is 
composed of the number of flash memory groups necessary for generating data of the same number of bits with the 
data access width of the central computing/processing means, wherein sequential order is regulated for the memory 
groups, storing files over multiple storage capacity units following this regulated order of memory groups, and when 
the number of storage capacity units increases by updating a once-stored file, the increase is secured from the 
memory group regulated in order as the next of memory group where the last data of the file were stored in the 
previous storing. 

[Claim 8] 

In an information processing device equipped with a central processing device and a file storage device, 
characterized by the fact that multiple flash memory elements are used as the storage media of the file storage device, 
where the minimum deleting unit of data of the flash memory is made to be equal to the storage capacity unit for file 
management, and if the number of storage capacity units when the central processing device requests file access is 
plural, the multiple flash memory elements are accessed simultaneously, and if the number of storage capacity units 
is one, one piece of the multiple flash memory elements is accessed. 

[Claim 9] 

In a file storage device having flash memory as its storage medium, a flash memory file storage device characterized 
by the fact that if the storage capacity of a file to record extends over multiple storage capacity units, it is equipped 
with a chaining information storage means which records information in the physical location where the next storage 
capacity unit is stored for each storage capacity unit. 

[Claim 10] 

In a memory element where multiple memory chips are embedded in a package, a memory element where the 
memory package is equipped with the corresponding number of input/output data temiinals to the total number of 
data inputs/outputs of all the memory chips, equipped with a data control means which controls 
switching/connecting input/output data of each memory chip and data input/output terminals and a control signal 
terminal for instructions from a memory user to the data control means, making it possible to switch/connect data of 
the multiple memory chips upon instructions of the control signal terminal to connect mput/output data of an 
arbitrary memory chip to an arbitrary terminal of the input/output data temiinals. 

[Claim 11] 

In a memory element where multiple memory chips are embedded in a package, a memory element where the 
memory package is equipped with the corresponding number of input/output data temiinals to the total number of 
data inputs/outputs of all the memory chips, equipped with a data control * means which controls 
switching/connecting input/output data of each memory chip and data input/output temiinals and a control command 
setting means for instructions from a memory user to the data control means, making it possible to switch/connect 
data of the multiple memory chips upon instructions of the control command setting means to connect input'output 
data of an arbitrary memory chip to an arbitrary terminal of the input/output data terminals. 

[Detailed Explanation of the Invention] 

[0001] 

[Field of Industrial Application] 

The present invention relates to information equipment loaded with a file storage device having flash memory as its 
storage medium, and especially relates to a file access method of file storage devices suitable for information 
equipment where high speed file access is demanded. 
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[0002] 

[Prior Art Technology] 

In today's general information equipment starting with personal computers, auxiliary storage devices are almost 
indispensable peripheral equipment. Moreover, in general, auxiliary storage devices are contained in most 
equipment, and arranged so that the users can always deal with files of large capacities. 

[0003] 

Recently, there are increasing cases where personal computers of notebook size and palm -top type are used, and 
portability is coming to be regarded important. Therefore, in place of magnetic disk storage devices which are weak 
in terms of vibration and have a large power consumption, file storage devices having semiconductors as their 
storage media are drawing attention. For example, disclosed in Pat Open Hei 2-292798 Public Report is a 
technology of a semiconductor file storage device using a flash memory as its storage medium. 

[0004] 

Flash memory is nonvolatile memory which can be electrically rewritten, and because capacity increase and cost 
reduction are possible, it is one of the most effective memories as storage media of semiconductor file storage 
devices. The technology in the Pat Open Hei Public Report uses this memory to solve the problems in constructing 
a file storage device and devices for improving the ease of use. For example, it proposes a method of overcoming 
the shortcoming of flash memory in which the elements become degraded by frequent rewriting, a method of 
increasing the speed in a phase called, deleting necessary for rewriting a flash memory, etc. Also, as an interface 
with information equipment which becomes a host, it proposes it to be the same as that for magnetic disk devices, 
directed towards the construction of systems that can replace magnetic disk devices. 

[0005] 

[Problems overcome by the Invention] 

The semiconductor file storage device of prior art technology uses the pre-existing interface bus of the host 
information equipment and places importance on compatibility with magnetic disk devices. Although this makes 
the semiconductor file storage device to be easily accepted by the users, in return for placing importance on 
compatibility with magnetic disk devices, no consideration is made on superiority of semiconductor storage 
elements to magnetic disk devices. 

[0006] 

Namely, although semiconductor storage elements enable very high speed data access because they are static 
recording media unlike magnetic disk devices which pick up data from rotating disks and perform writing, there is 
the problem that the superiority of this high speed access cannot be utilized with the same interface as with magnetic 
storage devices. 

[0007] 

It is an objective of the present invention to construct an interface which achieves high-speed access performance to 
the maximum by making semiconductor storage elements to be its storage media and to provide new auxiliary- 
storage devices which improve the access performance, which is a shortcoming of magnetic disk devices. 

[0008] 

[Problem Resolution Means] 

The flash memory file storage device by this invention is characterized by the fact that in a flash memory file 
storage device which is a file storage device storing data through an X-bit data bus and uses flash memory elements 
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whose minimum deleting unit is larger than the X bits and access width is x bits (x = X/p: p is an integer equal to or 
greater than 2).. it is equipped with a flash memory device consisting of p sets of flash memory element groups 
accessible simultaneously, dividing means which divide data on the X-bit data bus into at least p parts, a data 
distributing means which has at least a fust function to make p pieces of x-bit data obtained by the division 
correspond to one set of the flash memory element groups and a second function to make each of the p pieces of x- 
bit data correspond to another set of the flash memory element groups, and a control means which controls the data 
distribution means so that the first and second functions are switched according to the number of storage capacity 
units for file management of the access target file. 

[0009] 

[Operation] 

In magnetic disk devices used in the current person computers, data access is slower than the memory access of the 
personal computer and does not have to operate in synchronization with the CPU in the personal computer. 
Therefore, the give and take of data of magnetic disk devices are perform ed on an asynchronous bus. When a 
semiconductor is made to be a storage medium, because it can follow operations of the CPU, it becomes significant 
to make it a synchronous operation. 

[0010] 

How*ever : as a problem in such a case, there is the issue that the CPU processing bus width and the data access bus 
width of one chip of flash memory are different. Although this bus width difference can be solved by using memory 
chips in parallel in cases of DRAMs etc., flash memory has a fixed deleting unit where the minimum deletina unit is 
512 bytes, for example. In this case, if multiple chips are utilized in parallel, the capacity of a deletion unit that is 
deleted at once becomes (512 x the number of parallel chips) bytes. Thus, the deleting target capacity is so large 
that data other than the deleting target are also deleted. 

[0011] 

On the other hand, because personal computer file management currently regards this 512 byte unit as one sector, 
changing this storage capacity unit for file management (also called the file management unit, below*) should be 
avoided. Therefore, in accessing one sector which is the file management unit, if attempting to utilize four flash 
memory chips in parallel, the minimum deleting unit becomes larger as a result, and rewriting the sector will require 
deleting four times the capacity of one sector as described earlier. In order to avoid such a situation, if the CPU has 
a 32-bit bus and the flash memory has an 8-bit bus for example, one chip needs to be accessed four times 
sequentially to deal with the 32-bit bus of the CPU. 

[0012] 

However, when continuously accessing four sectors or more, there is no problem even if four chips are accessed 
simultaneously in parallel for each four-sector data and 32 bits from the CPU data bus are accessed simultaneously 
with a one-time access. Namely, if 512 bytes in the first sector are written by 32 bits at a time over 16 times, 1 28 
(16 x 8) bytes are dispersed to each step. Next, 512 bytes in the second sector are written by 32 bits at a time over 
16 times. In the same way, 512 bytes in the third sector, and further 512 bytes in the fourth sector are written. At 
this point of time, all the capacity of the minimum deleting units of four chips is filled with data. Therefore, there is 
no problem in deleting this four-sector capacity at once when rewriting this file. 

[0013] 

Thus, simultaneous four-step parallel access is repeated for each four sectors of a file. If there are data left which do 
not fill the last four sectors, other measures will become necessary. 

[0014] 
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If there arc three sectors left, because 32 bits of the CPU cannot be divided by 3, they are separated into two sectors 
and one sector for handling. 

[0015] 

If there are two sectors left, or the file is two sectors in size in the first place, 32-bit data from the CPU are divided in 
two, and two chips are simultaneously accessed by 1 6 bits each at a time. The 5 1 2 bytes in the first sector are 
written onto two chips by 16 bits at a time over 32 times, where 256 (32 x 8) bytes are dispersed onto each chip. In 
the same way, the 512 bytes in the second sector are written onto two chips by 16 bits at a time over 32 times. 

[0016] 

If there is one sector left, or the file is one sector in size in the first place, 32-bit data from the CPU are divided into 
four, and one chip is accessed by S bits at a time. The 51 2 bytes in the one sector are stored in one sector of the chip 
over 64 times. 

[0017] 

As with the above, changing the method of storing data according to the number of continuously accessed sectors 
contributes to an access speed increase and solves the deletion problem accompanying Hash memory. Namely, in 
either storing method, because it is guaranteed that only data of the same file are stored inside the minimum deletion 
area of a chip, the problem accompanying the deletion of flash memory is solved. 

[0018] 

Here, although the flash memory is operated synchronously in this invention, delays occur according to the access 
scheme. For this problem, a wait status can be arbitrarily requested to the CPU by using a CPU having a ready 
signal input. CPUs having a ready signal input are popular today. For example, it is installed in all CPUs having 1 6 
bit processing or higher by Intel Corp.. which are the most popular as CPUs mounted in general-use personal 
computers. Because the CPU halts its processing cycle by negating this ready signal, if reading' writing of access 
data has not been completed, this signal can be just negated, and when the access is complete, the CPU resumes 
execution of the processing by asserting it. Because this is a control which becomes possible only when the file 
storage device is in a synchronous operation with the CPU, inputting synchronized clocks to the both at this time to 
make them operate synchronously is indispensable. By these controls, even when the data width per single 
processing is different between the CPU and the flash memory, it can be easily dealt with by letting the CPU wait 
until the data widths are adjusted. 

[0019] 

It is usually impossible in file management to separate anything dealt with in a continuous sector once. Namely, a ■ 
file system can only access in file units. Therefore, when accessing multiple sectors continuously, if multiple chips 
are accessed simultaneously at the time of writing, using the multiple sectors in parallel, the file data as they were 
written can be obtained at the time of reading through the same parallel access. 

[0020] 

As in the above, according this invention, in an information processing device mounted with file storage devices 
having flash memories as its storage media, synchronous control with the system is performed so that the maximum 
performance can be drawn in it access performance which is highly superior to magnetic disk devices. In such a 
case, the CPU is put in a wait status upon necessity by a ready signal input to the system CPU to adjust the timing. 
Even when the system data bus width and the number of access data bits of one chip are different, it becomes 
possible to access at as high a speed as possible. 

[0021] 
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The effect is especially great in reading-' \vri ting of large capacity files whose access speed is easily recognized by 
the user, namely in continuous sector accesses. Also, whereas the system data bus width and the number of the 
access data bits of one chip are different according to the purpose, performance, and age, highly- flexible 
configuration is made possible to deal with various things. Also, it can be applied to methods to access memory 
with interleaves to increase the speed. 

[0022] 

According to the configuration equipped with a chaining information, the access procedure from the system is 
simplified to support a high-speed access. Then, the file management itself can be simplified, and simplification of 
control circuit, control program, etc. can be achieved. 

[0023] 

Also, by being equipped with a data distribution function inside a memory element, reduction of peripheral circuits 
and data processing speed increase can be achieved. 

[0024] 

[Embodiments] 

Embodiments of the present invention are explained hereafter, with reference to the drawings. 
[0025] 

First of all, shown in Fig. 1 is a standard personal computer configuration where the flash memory tile device of this 
invention is installed. In the figure, 1 is a CPU which in charge of processing data and programs, and its data bus 
width is assumed to be 32 bits. No. 2 is a clock generator which generates a synchronous clock for the whole 
system. No. 3 is a system internal bus containing a data bus, an address bus, memory commands, I/O commands, 
etc. No. 4 is a file control circuit which performs file management and memory* control of the flash memory file 
device of this invention. No. 5 is a flash memory array which becomes a storage medium of the flash memory file 
device, where the number of access data bits per chip is 8. no. 6 is a main memory control circuit which 
manages/controls the system main memory, and 7 is DRAM which is the main memory. No. 8 is a peripheral I/O 
bus control circuit, where a display control circuit 9 and a display 1 0 are connected as one of peripheral I/O devices. 
Listed as other peripheral I/O devices are a communication device 1 K an external large capacity storage device 12, 
etc. 

[0026] 

Usually, the peripheral I/O bus control circuit contains another clock generation circuit, and these peripheral I/O 
devices operate based on that clock cycle. However, there can be one which is directly connected to the internal 
system bus 3 for speed enhancement and operates in synchronization with the CPU 1. No. 13 is a clock signal 
supplied to each circuit containing the CPU 1 for synchronizing circuits connected to the internal system bus 3. 
Note that it does not need to be entirely the same with the clock supplied to the CPU 1 but can be a divided one 
depending on the circuit as far as it is synchronized. 

[0027] 

No. 14 is a ready control signal input to the CPU 1, where the status indication signals output from individual 
circuits are general -control led in a ready control circuit 15 and input to the CPU 1. No. 16 is a control circuit of 
input devices for the user of this system to instruct the desired processing, and 17 is an input device. In the figure, 
the input device is assumed to be a keyboard, and its control circuit 16 is assumed to be a keyboard controller 
(KBDC). 
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Next, actions of the system in Fig. 1 are explained. During normal operation, the CPU 1 computes/processes 
programs and data stored in the main memory 7 to execute the process that the user instructed through the input 
device 1 7, and displays the result on the display 10. Also, if necessary, it starts up the communication device 1 1 and 
stores a large capacity of data to the large capacity external storage device 12. Then, in retrieving or storing files, it 
operates the flash memory file device consisting of the file control circuit 4 and the flash memory 5. When booting 
up the system also, the system program is loaded from here. During these operations,, synchronous operations are 
performed by the clock 13 generated by the clock generator 2, and if there occurs a need for a certain circuit to 
request a stand-by to the CPU 1, that circuit request a CPU stand-by to the ready control circuit 15, and it is 
conveyed to the CPU 1 by negating the ready signal 14. The CPU 1 will continue to stand by until the ready signal 
14 is asserted again. At this time, the file control circuit 4 can perform a control of increasing'decreasing the CPU 
stand-by time by the number of files requested to the CPU 1 . This mechanism is explained with reference to Fig. 2. 

[0029] 

Figure 2 is a drawing to explain the internal configuration of the flash memory file device. In the figure, 3, 4, 5, and 
13 are the same as those in Fig. 1, and the following are internal components of the file control circuit 4. No. 21 is a 
register group which performs interfacing with the system bus 3, no. 22 is a status register for reporting the status of 
the file control circuit 4 to the CPU 1 , 23 is a register for setting the starting sector number to access, 24 is a register 
for setting the ending sector number to access, 25 is a command register which instructs the processing requested by 
the CPU 1 as a command code, and 26 is a data register which becomes a window of data give and take with the 
system bus. 27 is a controller which takes a general control of internal controls of the file control circuit 4, which is 
ideally a programmable, intelligent LSI such as a one-chip microcomputer. No. 28 is a control circuit which 
performs control of the flash memory 5 which is a storage 'medium, 29 is a data control circuit which performs 
control of data to read from or write to the flash memory. No. 30 is a DMA control circuit for performing memory 
access at high speed, and the system clock signal 1 3 is input to this circuit. No. 3 1 is a status indication signal 
output to the ready control circuit 15, no. 32 is a local bus mside this flash memory file device, and 33 is a control 
signal and address for accessing the flash memory. 

[0030] 

Next, actions of the flash memory file device in Fig. 2 are explained. When a necessity to access with the flash 
memory file device arises, the CPU 1 performs the access via the system bus 3. In order to do so, first the content of 
the status register 22 is read out to check whether it is in an accessible status or not. Then, the sector to access next 
is set to the starting sector register 23 and ending sector register 24. Then, it writes the command code (read or 
write) of the requested access to the command register 25. Then, the status register 22 is read again, and if the 
access is possible, data are written to or read from the data register 26. 

[0031] 

At this time, the controller 27 manages these interface registers 21 to respond to requests from the CPU 1 . Namely, 
it reads the starting sector register 23, ending sector register 24, and command register 25. grasps the access content 
of the flash memory 5, write a code indicating the current status to the status register 22, and reports to the CPU 1 . 

[0032] 

Because it is expected that the controller 27 is too slow in its operation speed to perform directly flash memory 
access for responding to the access requests from the CPU 1, the configuration is made so that the DMA control 
circuit 30 performs flash memory access at high speed and performs give and take of data with the system bus 3. 
The controller 27 will perform setting the access content, starting up the DMA, etc. to the DMA control circuit 30 
and the memory control circuit 28 for that purpose. 

[0033] 

The DMA control circuit 30 performs address generation and timing generation for performing the DMA, and the 
memory control circuit 28 generates access signals follow that timing. The flash memory 5 performs give and take 



FUSA 006019 



({ PAGE }) Pat Open Hei 6-266596 



of data with the data control circuit by these input signals. The data control circuit 29 performs data generation 
according to the number of sectors to access. 

[0034] 

For example, in the case of write access of one sector, data sent by one-time access from the system bus 3 are 
adjusted to the number of writing bits of one chip of flash memory. In this embodiment, because the data bus width 
of the system bus 3 is set to 32 bits, 32 bits of data are obtained through a transfer by one access. Then, because the 
data width of one chip of flash memory is set to 8 bits, the sent data are divided into four to write to the flash 
memory 5. Therefore, the processing of dividing 32-bit data into four 8-bit data is performed by the data control 
circuit 29 using a latch circuit. Also, in the case of read access of one sector on the contrary, the flash memory 5 is 
read accessed four times to prepare 32-bit data for one bus transfer. The wait time of the system bus occurring at 
this time is generated by a stand-by request to the CPU 1 by a status indication signal 31 generated by the data 
control circuit 29. 

[0035] 

On the other hand, in the case of access to multiple sectors, the data control circuit 29 adjusts the data to latch for 
increasing the access speed and execute it normally. For example, if it is a continuous read access of four sectors., 
because 32-bit data are completed by simultaneously reading four chips of 8 -bit access flash memory 5 r the waif 
time of the system bus 3 can be greatly reduced. Note that four-chip simultaneous write access needs to be 
performed at the time of writing to the flash memory 5. Otherwise, the order of data will come to differ and the file 
data will become abnormal. Note that because it is common to perform management with file units in systems 
dealing with file storage devices, it is usual to read-access the same number of sectors with the number of sectors 
when they were written, and if the access schemes according to the number of sectors are made entirely the same 
between writing and reading, there will be no need to record the information. Namely, if it is an access scheme of 
continuous writing of five sectors, the first four sectors are simultaneously written to four chips in parallel, and the 
remaining one sector is divided in four to one chip, adopted in both reading and writing for example, and normal file 
data can always be accessed. Here, to make sure, information on the data storing scheme may be recorded in data in 
sector units stored in the flash memory 5. As its record location, if there exists a redundant area other than the data 
storing area of the flash memory, storing there is appropriate, and if there is no redundant area, a separate storing 
area is installed for recording. 

[0036] 

A continuous access of six sectors is dealt with a parallel access of four sectors and a parallel access of two sectors. 
[0037] 

Next, these access signals and data control method are explained in even more detail with reference to Fig. 3. 
[0038] 

Shown in Fig. 3 is a configuration where the bit width of the system bus is set to 32 bits, and that of the flash 
memory to 8 bits. In the figure, numbers that already appeared before are identical to.those explained so far. Newly, 
41 is a counter for generating addresses of the DMA control circuit 30, where the system clock 13 and VO access 
(command) signals or memory access (command) signals of the system bus 3 are input and counting up is performed 
in synchronization with this. No. 42 is a start-up register for DMA control where the local bus 32 of the controller 
27 is connected, and a desired DMA transfer can be started by writing a code to this register. No. 43 is a sector 
register which is connected to the local bus 32, too, and DMA transfer of an arbitrary sector number can be 
performed by writing the sector number to access. In the actual operation, written value of this sector number is 
input to the memory control circuit 28 which is used for generating the upper-order address of the flash memory and 
chip select signal. No. 44 is a timing circuit which generates a timing signal for synchronizing in each control 
circuit at DMA transfer. No. 45 is a memory address generated by the memory control circuit 28 based on values of 
the counter 41 and sector register 43. No. 46 is a memory control signal generated by generation of the memory 
address 45. 51 . 52, 53, and 54 are data latches of one byte (8 bits) each, constituting data latches of four bytes (32 
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bits) for data width conversion between 32-bit data and 8-bit data. When data of the system bus 3 are denoted as 
D0-D31, the latch 51 latches D0-D7, the latch 52 D8-D15, the latch 53 D16-D23, and the latch 54 D24-D31, 
respectively. 55 is a latch signal generation circuit for these data latches. 56 is a data control setting register which 
is connected with the local bus 32 and sets data width and data order. In this embodiment, generation of a latch 
signal and its timing are instructed to the latch signal generation circuit 55 by setting one of "1", "2" and "4" to this 
data control setting register 56 as the number of continuous access sectors at read access. Then, latch signals input 
to data latches 51, 52, 53, and 54 are 57, 58, 59, and 60, respectively. For example, if "1" is set, latch signals 57, 58, 
59, and 60 are output sequentially one by one, and data from one chip of flash memory are accessed four times to 
generate 32-bit data which are output to the system bus 3. Also, if "2" is set, latch signals 57 and 58 are output 
simultaneously and afterwards latch signals 59 and 60 are output simultaneously, which are performed alternately, 
and data from two chips of flash memory are accessed twice each to generate 32-bit data which are output to the 
system bus 3. Also, if "4" is set, latch signals 57, 58, 59, and 60 are output simultaneously, and data from four chips 
of flash memory are accessed only once to generate 32-bit data which are output to the system bus 3. 

[0039] 

On the other hand, during a write access, latch signals are always sent to data latches 51, 52, 53, and 54 
simultaneously to latch 32-bit data from the system at once. No. 61 is a data distribution circuit which distributes 
data stored in data latches 51, 52, 53, and 54 or data from the memory' 5. No. 62 is a 32-bit data bus connecting the 
flash memory 5 and the data distribution circuit 61. No. 63 is a read/write signal for determining the data direction 
of the data distribution circuit 61. which should better receive supply from the command register 25 of the interface 
register 21. The data distribution circuit 61 is made as a bidirectional buffer, where one side is connected to data 
latches 51, 52, 53, and 54, and the other side to the flash memory 5. On the flash memory 5 side, the input is in 32 
bits, and all the chips of the flash memory 5 are divided into four groups, which are divided into separate bit groups 
(Bits 0-7), (Bits 8-15), (Bits 16-23), and (Bits 24-31), and input as 32 bits in total. Then, the direction is 
determined by whether it is read or write, and partitioning of each data are determined by the setting content of the 
data control setting register 56. 

[0040] 

Specific explanations are given on this distribution of data using Fig. 12, Fig. 13, and Fig. 14. These figures show 
data distribution examples of the data distribution circuit 61 for different values set to the data control setting 
register 56. Figure 12 shows data distribution when the number of continuous access sectors is 1, Fig. 1 3 when the 
number of continuous access sectors is 2, and Fig. 14 when the number of continuous access sectors is 4, 
respectively, and there are four kinds of data distributions in each case depending on which of the four memory 
groups to access. Also, read and write are distinguished. When the number of continuous access sectors is 1 , four 
system cycles make one access, when the number of continuous access sectors is 2, two system cycles make one 
access, and when the number of continuous access sectors is 4, one system cycle makes one access. 

[0041] 

When the number of continuous access sectors is 1, classification into four kinds is made depending on where in the 
divided memory to access, and when the number of continuous access sectors is 2 or 4, classification into four kinds 
again is made depending on which memory group is set as the starting point. Namely, the starting point can be 
adequately determined depending on how the memory is used, and by doing so the bias of used memory groups can 
be prevented. For example, although the data distribution method can be simplified if the memory group 1 is always 
set as the starting point, it is expected that the ratio of usage of the memory group 1 becomes high and there occur 
biases in both the amount of use and the frequency of use. If a bias occurs, one memory group eventually becomes 
unavailable, making is impossible to perform high-speed write access when the number of continuous sectors is 4. 
Therefore, it is made possible to set the starting point in any memory group. 

[0042] 

Note that although in reading when the number of continuous sectors is 1 or 2, data connection lines in the 
distribution circuit are made separate for each cycle in the figure, because the latch signal is not output to other than 
the target latch : the connection line may be shared instead of separating for each cycle. Namely, in reading of A 
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where the number of continuous sectors is 1 (Fig. 12), whereas the distribution is performed in a sequential cycle 
with latch 1 - memory group 1, latch 2 - memory group 1, latch 3 - memory group 1, and latch 4 - memory group 1, 
connection lines to all the latches may be connected to 1 of the memory group in all cycles. This is because even if 
data lines are connected, there is no influence if no latch signal is output. 

[0043] 

More specifically, referring to Fig. 12 in the write access of one sector for example, one byte connected one of the 
access target flash memory groups among the 32-bit data bus 62 is written to the flash memory with the data latch 
51 at the first time, the data latch 52 at the second time, the data latch 53 at the third time, and the data latch 54 at 
the fourth time, which is repeated from 51 sequentially. In the read access, one cycle of data are distributed to each 
latch by the latch signal. 

[0044] 

Ln the write access of two sectors, namely, if it is a write with a data width of 2 bytes, from Fig. 13, as 2-byte data 
connected to the corresponding two memory groups among the 32-bit data bus 62, data are received from the data 
latches 51 and 52 at the first access, 53 and 54 at the second access, and distributed alternately afterwards. On the 
other hand, in the read access the order becomes reversed, and data are distributed from the corresponding two 
memory groups to the data latches 51 and 52 in the First access, 53 and 54 in the second access, and this is repeated. 

[0045] 

In the write access of four sectors, namely, if it is a write with a data width of 4 bytes, the buffer direction becomes 
the one from the data latch to the flash memory 5, the 32-bit data bus 62 is connected to the data latches 51, 52, 53, 
and 54 sequentially from its top memory group, and 32-bit access is completed by one-cycle access. In reading, the 
direction becomes the opposite. 

[0046] 

In order to perform the actions, the controller 27 needs to set appropriate values to the registers explained so far 
before starting up the DMA control circuit 30. 

[0047] 

When multiple memory groups are accessed simultaneously in order to increase the speed as described earlier 
addresses given to the individual memory groups are investigated below referring to Fig. 5. 

[0048] 

In Fig. 5. 81-84 indicates memory groups 1-4, respectively. The same figure (1) shows a state where a certain 
amount of file writing has been performed and the same figure (2) shows a state where a certain file has been 
updated and its file size has increased. The data code (m-n) shown in the figure indicates a file number m and a 
sector number n in each file. For example, (3-2) indicates the second sector of the file number 3. Note that this 
figure shows area (having a capacity of one sector or more) of which memory group is used how as a whole, and in 
actuality, at a continuous access of two sectors or more, instead of content of only a single sector being stored in a 
one-sector capacity area of each memory group, contents of multiple sectors are stored dispersed. This point will be 
described in detail later in the explanation of file management. 

[0049] 

In Fig. 5 (1), in the access of file number 1 (all sectors coded as l-n) 5 in a simultaneous access from 1-1 to 1-4, 
because these are arranged in the same line, same address can be given to these memory groups. However, in file 
number 2, if 2-1 to 2-4 are used for a simultaneous access, the memory group 4 needs to be given a different address 
from other memory groups. This means that the same number of address buses with the number of memories need 
to be installed. Or, there needs to be some way to give different addresses to the memory groups. In order to avoid 
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this, an access scheme needs to be taken in accesses of file number 2 that 2-1 is accessed alone, 2-2 and 2-3 are 
simultaneously accessed, and 2-4 is accessed alone again. However, this will generate a waste in increasing the 
speed. Then, an example of configuration for giving different addresses is explained using Fig. 9. 

[0050] 

Figure 9 is an example of configuring an address generation circuit inside the memory control circuit 28 when the 
number of memory groups is set to 4. In the figure, 201-204 are four memory groups constituting the flash memory 
5, where 201 is a first memory group a, 202 is a second memory group b, 203 is a third memory group c, and 204 is 
a fourth memory group d. 205 is a latch circuit b of the high-order address given to the memory group b, 206 is a 
latch circuit c giving to the memory group c, and 207 is a latch circuit d giving to the memory group d. 208 is the 
address bus of the memory control circuit 28 (corresponding to 45 in Fig. 3), and 209 is the low-order address of the 
address bus 208. The number of its address bits is set to the number of address bits which corresponds to that for 
accessing the storage capacity of the data deletion minimum unit or the minimum unit for file management of the 
Hash memory chip. For example, if the data deletion minimum unit is 51 2 bytes, it becomes 9 bits. Only when the 
data deletion minimum unit of the Hash memory chip is smaller than the minimum unit for file management, it is 
effective to make it the number of address bits which corresponds to the minimum unit for file management. 210 is 
the high-order address of the address bus 208 excluding the low-order address 209. Note that even higher-order 
address which is unnecessary in accessing the memory groups is removed. No. 211 is a high-order address stored in 
the address latch b for accessing the memory group b, 212 is a high-order address stored in the address latch c for 
accessing the memory group c, and 213 is a high-order address stored in the address latch d for accessing the 
memory group d. No. 214 is a memory control signal for the memory group a201, 215 is a memory control signal 
for the memory group b202, 216 Is a memory control signal for the memory group c203, and 217 is a memory 
control signal for the memory group d204. 

[0051] 

In the configuration of Fig. 9, when accessing the memory group a to the memory group d simultaneously, high- 
order addresses to access these memory groups are written in advance to the address latches 205-207. Then, when 
performing the access, because the low-order address 210 is common to all the memory groups, the address bus 
supplies the address for accessing only the memory group a, and memory groups other than the memory group a are 
accessed through the high-order addresses from the corresponding address latch circuit. Note that access control is 
entrusted to the memory control signals 214-217, and if access is only to the memory group a and the memory 
group b for example, it is arranged so that only the memory control signals 214 and 215 become active. Also, in 
accessing only the memory group d for example, unless the memory control signal 21 is set active, the memory 
group a may be give any address without a problem. By this means, it becomes possible to give different addresses 
to individual memory groups, only if the memory groups are dispersed into 4, data of the same file stored in 
locations at physically different addresses can be accessed simultaneously, enhancing the contribution of speed 
increase. In the configuration of Fig. 9, the address latch of the memory group a can be omitted. Of course, if it is 
effective to install an address latch also for the memory group a, it may be done so. 

[0052] 

According to the above embodiment, the CPU 1 can perform read/write access of a desired sector at high speed by 
performing simple specifications to relatively a small number of registers. Also, the file controller is made as a one- 
chip microcomputer, where fine control can be instructed by software, and data transfer can be performed at high 
speed by loading a DMA transfer control circuit even if the one-chip microcomputer can only perform slower 
operations than the system. However, if the operation speed of the one-chip microcomputer is high enough to 
perform high-speed operations for the system, the DMA control circuit is not necessary, and a configuration where 
all data transfers are performed by the one-chip microcomputer can also be considered. 

[0053] 

Also, although an explanation has been given in this embodiment assuming the data buses are 32 bits for the system 
and 8 bits for the flash memory, also for the CPU 1 of 16-bit operation, CPUs of 64-bit operation, and a flash 
memory of 16-bit I/O, adjustment to other data widths can be easily performed by changing the number of data 
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latches, configuration of the data control setting register, and control programs of controllers. The concrete example 
is shown in Fig. 15. Shown in Fig. 15 are concrete numerical values of hardware configuration in a combination of 
individual bit widths. The horizontal configuration of the figure is the number of data bits of the flash memory, 
where 4 bit, 8 bit, 16 bit, and 32 bit are listed as examples. The vertical configuration shows the system data width, 
where 8 bit for simple information equipment, 16 bit and 32 bit which are the mainstream of the present personal 
computers, and 4 bit and 128 bit for the future personal computers and high-performance computers are listed as 
examples. Also, the data distribution circuit listed as a hardware configuration is, if explained using the data 
distribution circuit 61 of the embodiment, shown in the number of bits of one circle x the number of circles in the 
figure. Connection of each circle can be shown in the same idea with Fig. 12 ~ Fig. 14. While the number of 
latches is increase or decrease of the number of latches 51-54 in the embodiment, if the number of memory data bits 
is larger than the system data width, the latch location will be configured in the data distribution circuit memory side. 
The number of memory groups indicates the number of divisions of the memory which is divided in four in the 
embodiment. 

[0054] 

Note that the number of distribution of the data distribution circuit, the number of latches, and the number of 
memory groups are lower limit numbers including this embodiment, and if there is some room in the circuit scale, 
the number of terminals, etc., increasing them will make a more effective system configuration. That is because 
increasing the number of memory groups gives more room in selecting memory for storing data, which can prevent 
biases of memory usage and frequency of use. Also, because the number of memories to access in parallel can be 
increased, speed increase can be further progressed. Especially, when the system data width and the number of 
memory data bits are equal to each other or the number of memory data bits is larger, although there is no effect of 
adjusting the data bus widths at all as described in the embodiment, multiple memory chips can be simultaneously 
accessed and speed increase by the so-called interleave method can be realized. In this case, at the same time with 
increasing the number of memory groups, the number of memory data distributions in the data distribution circuit 
and the number of latches need to be increased. 

[0055] 

Note that although explained in this embodiment is that the flash memory can follow data transfer from the system, 
to do so it is preferable that a write buffer be installed inside the flash memory. If it is a flash memory which can 
perform writing -at high speed in the future, this kind of write buffer will become unnecessary. If no write buffer is 
contained in the flash memory, a write buffer can be installed between the flash memory and the data control circuit. 
Then, at each write access, writing is performed not directly to the flash memory but first to the write buffer, and 
after data transfer from the system is complete, writing is performed from the write buffer to the flash memory. The 
configuration diagram of an embodiment of this case is shown in Fig. 4. 

[0056] 

In Fig. 4, numbers which already appeared before are the same with those explained so far. As new ones, 71 is a 
data selector which switches connection with the data distribution circuit 61 depending on whether the access is read 
or write, 72 is a write buffer of 32-bit width which temporarily stores write data, and 73 is a read/write signal for 
switching the data selector 71, where a part of data of the command register 25 is better to be input. If the access is 
write, the data distribution circuit 61 is connected with the write buffer, write data are stored in the write buffer, and 
the controller performs writing to the flash after data transfer from the system. If it is read, the data distribution 
circuit 61 is connected directly to the flash memory, and the same operation with the read access in Fig. 3 describe 
above is executed. By making it the configuration, even using a flash memory which does not contain a write buffer 
and has a slow writing, high-speed accesses become possible, seen from the system. 

[0057] 

Next, an embodiment of file management is explained with Fig. 5 as an example. Although embodiments of 
hardware have been explained so far, how to store actually to the flash memory is described below*. This operation 
is basically performed by the system CPU, system program, and the controller of the flash memory files, where the 
central issue is operation by software. In the explanation using Fig. 5, instead of the content of the software itself. 
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shown is how unit capacity area (for one sector) of each memory group of the flash memory as the whole is assigned 
to a sector of a file as a result of the operation. For each sector of a file, unit capacity area is secured in sequential 
memory groups. For continuous sectors of four or more, one unit capacity area of sequential memory groups 1-4 
are assigned to the four sectors (1-1-1-4 in the figure for example). Note that data in each sector are actually stored 
dispersed in four unit capacity areas. To two sectors (1-5-1-6 in the figure for example), unit capacity areas of two 
memory groups are assigned. In this case also, data in each sector are stored dispersed in two unit capacity areas. 
Assigned to the last sector 1-7 of file 1 is a unit capacity area of a single memory group. 

[0058] 

Here, an even more detailed explanation is given on dispersed storing of two sectors and four sectors using Fig. 10 
and Fig. 11. Shown in Fig. 10 is an example of 4-byte simultaneous write, and Fig. 11 is an example of 2-byte 
simultaneous write. In the same ways as the above, it is assumed that the host system bus is 32 bits, and that the 
memory access width of one memory group is 8 bits. 

[0059] 

Shown in Fig. 10 is an example of 4-sector simultaneous write to the memory groups a-d. In the figure, indicated 
with 211 is data from the system bus, which are sent with 32 bits (4 bytes) as. a unit. Indicated with 222-225 are 
sequential numbers of 8-bit (1-byte) unit data, 222 is the first byte data 223 is the second byte data, 224 is the third 
byte data, and 225 is the fourth byte data. Following them, data up to the 2048th byte are continuously sent as those 
for 4 sectors. Actually, because of the 32-bit bus, from the first byte to the fourth byte are simultaneously received, 
and the following are the same. Nos. 5 1-54 are data latches for temporary storage of data shown in Fig. 3. 

[0060] 

Because of being simultaneously written 4 bytes at a time, after storing 32 bits, namely 4 bytes, simultaneously to 
the data latches 51-54, each byte is dispersed to the memory' groups a-d and is written one byte each. For the next 
32-bit data, each byte is written to the following parts of the memory groups a-d. In this way, when 512 bytes 
corresponding to 1 sector are written, subsequently data for the second sector are written by 4 bytes at a time to the 
following parts of the memory groups a~d in the same way. Although Fig. 5 is shown for convenience as if each 
sector is assigned to a specific memory group, as in the above explanation, actually data in each sector are not stored 
only in a specific memory group but written dispersed to the memory groups a-d. Note that it is true that data of the 
whole 4 sectors are stored in an area of 4-sector capacity in the memory groups a~d. 

[0061] 

Shown in Fig. 11 is an example of 2-byte simultaneous write to the memory group a and the memory group b. 
[0062] 

Because of being a simultaneously written 2 bytes at a time, after storing 32 bits, namely 4 bytes, simultaneously; to 
the data latches 51-54, these are divided in two by 2 bytes each, the first half 2 bytes are first written to the memory 
group a and the memory group b by 1 byte each, next the latter half 2 bytes are written to the memory group a and 
the memory group b by 1 byte each. In this way, when 512 bytes corresponding to 1 sector are written, 
subsequently data for the second sector are written from the first byte to the following parts of the memory groups a 
and b in the same way. In this case also, the first sector is not stored only to a specific memory group but written 
dispersed to the memory groups a and b, and in the same way, the second sector is written dispersed to the memory 
groups a and b following the first sector. 

[0063] 

Although writing to a single sector is not shown, individual byte data of the data latches 51-54 are simultaneously 
stored to a certain memory group sequentially in this case. Only in this case, data of one sector are stored to a 
specific memory group without being dispersed. 
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[0064] 

As can be seen from the above, the important thing is that there is no data mixed from different tiles in the area of 
the minimum deletion unit (512 bytes corresponding to one-sector capacity here) of a flash memory element as a 
result of the above operations. By this guarantee, it becomes possible to achieve high-speed file data storing by 
writing multiple bytes simultaneously in parallel as effectively utilizing the storage area of memory when rewriting 
a file without deleting data of other files. 

[0065] 

As stated above, Fig. 5 (1) shows a state where a certain degree of file writing has been performed, Fig. 5 (2) a state 
where a certain file has been updated and the file size has increased afterwards In Fig. 5 (1), storing is performed so 
that different memories are assigned in the order of file numbers to be stored and the order of sector numbers. In 
principle, they are packed to leave no space so that there will be no waste in terms of management. 

[0066] 

As shown in Fig. 5 (1), if file sectors are stored in memory groups by packing sequentially and continuously so that 
no vacant space occurs, when a File size has increased by updating the file, there occurs cases as shown in Fig. 5 (2) 
where continuous storing in terms of physical storage location is impossible. Even in such a case, storing is 
performed so that the order of memory groups becomes continuous. Namely, if the file number 4 is taken as an 
example, while five sectors from 4-1 to 4-5 are stored in (1). if two sectors are added in (2), because 4-1 is started 
from the memory group 3. areas in the memory groups 2 and 3 are secured for the increased portion of 4-6 and 4-7. 
When writing a file whose number of sectors is increased, 4-5 and 4-6 are treated as 2 -sector continuous sectors at 
this time, and 4-7 is treated as a single sector. Namely, added sectors also receives a treatment as continuous sectors 
together with already-stored sectors. In order to perform smoothly these storing and reading out in file management 
it is believed to be more appropriate as a hardware configuration that specification of access sectors from the system 
should be the starting sector and the number of sectors and grasping the physical storage locations should be 
performed inside the file system. Namely, whereas specifying access files from the system should be simplified as 
much as possible for the speed increase, if physical locations are scattered, specifying the physical locations 
becomes complicated Therefore, the ending sector 24 shown in Fig. 2 should be removed in this sense. Then, by 
storing information indicating file chaining in an redundant area of the memory to store information other than data 
if it exists, or in another storage means if it does not exist, because if the file starting number is specified, all the 
physical locations of sector numbers following it become clear by chaining, a continuous access becomes possible. 

[0067] 

Shown in Fig. 6 is an example of chaining infonnation. In the figure, 85 is file data stored in memory, which are 
data of file number 4 and sector number 5. 85 is the data of file number 4 and sector number 6 that follow them. 
And 87 is data of file number 4 and sector number 7 that further follow them. Note that although these data are 
arranged in the order of the sector numbers, they may be mixed in the actual storage state. Namely, data may be 
stored scrambled by accessing multiple chips simultaneously through a continuous sector access. However, because 
numbering of data storage by byte is necessary even in such a case, sector numbers are very important. 88 is a 
physical address indicating the physical location on memory where the file data 85 are stored, where the number "3" 
on the left side is the me mow group number, the number tk 5" on the right side is the address in that me mow group. 
89 and 90 are physical addresses of the file data 86 and the file data 87 in the same way. 91 is chaining information 
indicating the physical address where the next sector of the file data 85 are stored, and because the file data 85 are 
data of file number 4 and sector number 5, the chaining information 91 indicates the physical address where data of 
file number 4 and sector number 6 are stored. The number on the left side is the memory group number, and the one 
on the right side is the address in the memory group. In the same way, chaining information 92 indicates the 
physical address where data of file number 4 and sector number 7 are stored, and chaining infonnation 93 indicates 
a case where the next sector does not exist. Namely, it can be told that the file of file number 4 ends with 7 sectors. 
If this chaining information is attached with file data, the system CPU does not have to grasp the physical location 
of file storage but can take a scheme of simply accessing the file itself. Then, by the controller of file control 
performing physical accessing of memory as referring to the chaining information, even with a file whose physical 
storage locations are not continuous but scattered a continuous access becomes possible. In that case, a 
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configuration to input different addresses for simultaneous access of different memory groups is necessary. Note 
that as stated earlier in Fig. 9, low-order address for the one-sector access can be shared, necessity is only for the 
high-order address for more than that. According to embodiments using chaining information above, access 
specification from the system can be simplified to enable the execution with smaller amount of information. 

[0068] 

Next, an explanation is given on an embodiment of embedding various kinds of functions in a memory element 
itself. 

[0069] 

Figure 7 is a configuration diagram of a memory element where multiple memory chips are contained in a package 
and an additional circuit is installed. In the figure, 101 is a memory package, 102-105 are memory chips having the 
same function, 106-109 are input/output data terminals of the memory package 101. each of which can perform data 
input/output of one memory chip. For example, if the memory chip 102 has S-bit data input/output, 106-109 come 
to have 8 bits x 4 = 32 bits of data input/output terminals in total. No. 1 1 0 is a signal input terminal which specifies 
the path to connect these memory chips with input'output terminals, 311 is a specification signal, and 112 is a 
connection path setting circuit. A user of this memory 101 executes an access after setting 109 with the signal input 
terminal 110 from the data input/output terminal 106. It is considered as an example that this setting is selected 
from connection paths such as those in Fig. 12, Fig. 13, and Fig. 14 stated earlier. In the memory 101, set data 
connection is sent as the specification signal 111 to the connection path setting circuit 1 12, the connection setting 
circuit 112 connects the memory chips 102-105 with the data input/output terminals 106-109 according to the 
setting, and realizes connection of data in the memory chip with the desired data bus. 

[0070] 

Figure 8 is a configuration example of a memory element which performs setting of data connection from a user by 
a command input. In the figure, 1 13 is a command control circuit which creates the specification signal 1 1 1 from a 
register of the command set value and its set value. 1 14 is a data line where the user set the command set value 
using a part of the data input/output terminal. Others are the same as those with the same numbers in Fig. 7. A user 
selects a data connection path with Fig. 12, Fig. 13, and Fig. 14 as an example, sets as a command code from a part 
of data bus 1 14 to the command control circuit 1 13, and sends the specification signal 1 1 1 which corresponds to the 
connection path setting circuit 1 12 from the command code set in the command control circuit 1 13. Below is the 
same as the explanation of Fig. 7. According to this embodiment by Fig. 7 and Fig. S, another embodiment 
explained so far can be realized as a memory element, and there is an efficacy that reduction of peripheral circuits 
can be achieved. Note that although in this embodiment multiple chips and control circuits are to be loaded in a 
memory package, by uniting these into one chip, miniaturization and speed increase can be promoted. 

[0071] 

[Efficacy of the Invention] 

According to the present invention, it becomes possible in a flash memory device to achieve high-speed file data 
storing by writing multiple bytes simultaneously in parallel as effectively utilizing the storage area of the memory 
when rewriting a file without deleting the data of other files. 
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[Brief Explanation of the Drawings] 

[Fig. 1] A block diagram showing a system configuration which realizes this invention. 

[Fig. 2] A block diagram showing the configuration of an embodiment of the flash memory' file device. 

[Fig. 3] A block diagram of the main section for explaining actions of the embodiment. 

[Fig. 4] An explanatory drawing showing data control when a slow- writing flash memory chip is used in the 
embodiment. 

[Fig. 5] An explanatory drawing of an execution example of storing files to the memory in the embodiment. 

[Fig. 6] An explanatory drawing of an execution example of storing chaining information in another embodiment of 
this invention. 

[Fig. 7] An explanatory drawing of a memory configuration example where the data distribution function by the 
signal terminal input specification is installed in the memory element. 

[Fig. 8] An explanatory drawing of a memory configuration example where the data distribution function by the 
command setting input specification is installed in the memory element. 

[Fig. 9] An explanatory drawing of address connection of the memory groups in the embodiment. 

[Fig. 10] An explanatory drawing of actions at 4-byte simultaneous write in the embodiment. 

[Fig. 1 1] An explanatory- drawing of actions at 2-hyte simultaneous write in the embodiment, (system bus 32 bit,) 

[Fig. 12] An explanatory drawing of data distribution at memory 1-chip simultaneous access in the embodiment. 

[Fig. 13] An explanatory drawing of data distribution at memory 2-chip simultaneous access in the embodiment. 

[Fig. 14] An explanatory drawing of data distribution at memory 4-chip simultaneous access in the embodiment. 

[Fig. 15] An explanatory drawing of hardware configurations in various configurations of the system bus and the 
memory data bus. 

[Explanations of the Codes] 

1: CPU, 2: Clock generation circuit, 3: System bus, 4: File control circuit. 5: Flash memory. 6: Main memory 
control circuit, 7: Main memory, 8: External I/O control circuit, 9: Display control circuit, 11: Communication 
circuit, 12: Large capacity external storage device, 13: System clock, 15: Ready control circuit, 16: KBDC, 21: 1/F 
register 22: Status register, 23: Starting sector register, 24: Ending sector register 25: Command register, 26: Data 
register 27: Controller, 28: Memory control circuit, 29: Data control circuit, 30: DMA control circuit 31: Status 
indication signal, 32: Local bus, 41 : Counter, 42: Startup register, 43: Sector register 44: Timing control circuit 45: 
Address, 46: Control, 51: Latch circuit, 52: Latch circuit, 53: Latch circuit 54: Latch circuit 55: Latch circuit 
generation circuit, 56: Data control setting register, 61: Data distribution circuit 63: Read/write signal 71: Data 
switching circuit, 72: Write buffer, 73: RAV signal, 85: Data (4-5), 86: Data (4-6), 87: Data (4-7), 91: Chaining 
information, 101: Memory package, 110: Specification signal input terminal, 112: Connection path setting circuit 
113: Command control circuit, 201: Memory group a, 202: Memory group b s 203: Memory group c, 204: Memory 
group d, 205: Address latch b, 206: Address latch c ; 207: Address latch d, 208: Address bus, 209: Low-order address, 
210: High-order address, 214—217: Memory control signals. 
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